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La page 1/5 est à compléter par le candidat et à rendre avec sa copie. 


Exercice 1 (3 points) 


Dans un contexte de base de données, mettre une croix (X) dans la case qui correspond à la bonne 
réponse pour chacune des propositions suivantes : 
1. La contrainte d'intégrité référentielle permet de/d' : 

EA interdire les doublons dans une clé primaire 

ni interdire les doublons dans une clé étrangère | 

[| vérifier la validité des valeurs d’une colonne dans une table 

ES 


modifier automatiquement la valeur d'une clé étrangère en cas de mise à jour de la 
valeur de la clé primaire correspondante 


2. En langage SQL, pour ajouter une clé primaire dans une table existante, on utilise une requête avec 
la syntaxe suivante : 

ALTER TABLE <nom_table> ADD <nom_colonne> NOT NULL 

ALTER TABLE < nom_table > ADD REFERENCES < nom_table > (<nom_colonne >) 

ALTER TABLE < nom_table > MODIFY < nom_colonne > PRIMARY KEY 


UUL 


ALTER TABLE < nom_table > ADD PRIMARY KEY (<nom_colonne>) 


3. En langage SQL, la clause permettant d'éviter les redondances dans le résultat d'une requête de 
sélection est : 

DISTINCT 

GROUP BY 

ORDER BY 

WHERE 


HUUL 
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Exercice 2 (3 points) 

Soit la table STOCK d’une base de données permettant à une société de confection textile de gérer la 
vente de vêtements dans différentes boutiques. 

Dans ce qui suit, on donne la représentation textuelle de cette table ainsi que la description de ses 


colonnes et un extrait de son contenu. 


Représentation textuelle Extrait du contenu 


STOCK ( IdArt, IdBout, QteStock ) a + dBour À te 


Description des colonnes 


Description 





Questions 
1. Ense référant aux éléments ci-dessus, répondre aux questions suivantes : 
a. Quelle est la contrainte d'intégrité non respectée lors de la création de cette table ? 
b. Pourquoi la colonne IdArt ne peut pas être considérée comme étant une clé primaire de cette 
table ? 
c. Proposer une clé primaire pour cette table. 
2. Qu'appelle-t-on la contrainte qui oblige les utilisateurs à saisir des valeurs positives dans la colonne 


« QteStock » ? 
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Exercice 3 (6 points) 
Soit «DB_Sejours» la base de données simplifiée permettant à une association de gérer différents 
types de séjours (Culturel, Loisir, Aventure, etc.). Cette association organise des séjours au profit de 
ses adhérents vers plusieurs pays du monde pendant différentes périodes de l’année. 
Dans ce qui suit, on propose la représentation textuelle de la base de données «DB_Sejours» : 

PAYS (IdPays, NomPays) 

TYPESEJOURS (CodeType, LibType) 

SEJOURS (NumsSej, IdPays#, CodeType#, DateDebut, DateFin) 


Soit la description des colonnes des tables de cette base : 


Identifiant du pays 


| 


NomPays Nom du pays 
CodeType Code du type de séjour 


LibType Libellé du type de séjour 
Numéro du séjour Entier 
DateDebut Date de début du séjour Date 


DateFin Date de fin du séjour Non vide 





N.B. On suppose que les tables PAYS et TYPESEJOURS sont déjà créées et non encore remplies. 


Questions 

1. Ecrire la requéte SQL permettant de créer la table SEJOURS. 

2. Ecrire la requéte SQL permettant d'ajouter la contrainte de domaine sur les colonnes DateDebut 
et DateFin de sorte que DateDebut soit inférieure à DateFin. 

3. On se propose d'insérer dans la base de données le séjour N° 125 relatif au type de séjour de 
code 3 et de libellé "Aventure", vers "Kenya", pays d'identifiant 88 pendant la période du 
25/08/2021 au 04/09/2021. 

Ecrire les requêtes SQL permettant d'insérer les données relatives à ce séjour dans les différentes 


tables. 


Voir suite au verso & 
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Exercice 4 (8 points) 

La société privée « Express_Transport » est spécialisée dans le transport de passagers dans un réseau 
urbain de bus. 

Ci-dessous, la représentation textuelle de la base de données simplifiée qu’elle utilise pour gérer ses 


différents voyages. 


CONDUCTEUR (MatCond , NomPreCond, TelCond, AdrCond) 
VILLE (CodeVil , NomVil) 





BUS (ImmatBus , DateCirBus, EtatBus) 
TRAJET (NumTraj, KmTraj, CodeVilDep#, CodeVilArr#) 
VOYAGE (IdVoy, DateHeuDep, DateHeuArr, MatCond#, NumTraj#, ImmatBus#) 


Soit la description des colonnes des tables de la base de données « Express_Transport » : 


BE- 
30 
5 
20 





y 


-Contrainte 


MatCond Matricule du conducteur | T Entier 


NomPreCond | Nom et prénom du conducteur | Texte 
TelCond Téléphone du conducteur 
Adresse du conducteur 


Code de la ville 
Nom de la ville 
Immatriculation du bus 
































































DateCirBus | Date de mise en circulation du bus | Date E 
EtatBus Etat du bus Caractère 3 à, En is 
H' : Hors service 
NunTraj Numéro du trajet Entier 
Distance parcourue en kilomètre Entier 







CodeVilDep Code de la ville de départ Texte 
CodeVilArr Code de la ville d'arrivée Texte 
IdVoy Identifiant du voyage Entier || | 
DateHeuDep | Date et heure de départ du voyage | Date et Heure | | Nonvide | 
DateHeuArr Date et heure d'arrivée du voyage | Date et Heure À 
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Questions 


1. Afin d'obtenir des statistiques sur le nombre de voyageurs, l'administrateur se propose d'ajouter 


dans la table VOYAGE une nouvelle colonne intitulée « NbrVoyageurs » dont les valeurs doivent 


être strictement supérieures à 8. 


Ecrire la requête SQL permettant d'ajouter cette colonne. 


2. Ecrire les requêtes SQL permettant d'afficher : 


a. 


la liste des bus (ImmatBus, DateCirBus) dont l’année de mise en circulation est supérieure ou 
égale à 2020. 

la liste des bus (toutes les informations) qui sont hors service. 

la liste des conducteurs (MatCond , NomPreCond, TelCond) ayant conduit le bus immatriculé 


"220 TU 5738" tout en évitant d'afficher plusieurs fois un même conducteur. 


. la liste des voyages (NumTraj, ImmatBus, DateHeuDep) dont la ville de départ est "Tunis", 


triée par ordre croissant de leurs dates et heures de départ. 


pour chaque bus, son immatriculation et le nombre de kilomètres parcourus. 
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Épreuve : Bases de données- Section : Sciences de I 'informatique- Session principale 2020 
Feuille à compléter par le candidat et à rendre avec sa copie. 


Exercice 1 (4,5 points) 


Soient les requêtes SQL présentées ci-dessous permettant de créer les tables DEPARTEMENT et EMPLOYE : 





CREATE TABLE DEPARTEMENT (IdDept Int PRIMARY KEY, 
NomDept Varchar(20) UNIQUE); 
CREATE TABLE EMPLOYE (IdEmp Int PRIMARY KEY, 
NomEmp Varchar(30) NOT NULL, 
IdDept Int REFERENCES DEPARTMENT(IdDept) ON DELETE CASCADE, 
SalEmp Decimal(12,3) CHECK (SalEmp > 1000 AND SalEmp < 3000), 
SitEmp Char(1) DEFAULT 'T'); 












Description des colonnes des tables 


Nom de 
la colonne 







Namee Description 
la colonne 
IdDept Identifiant d'un département 
NomDept | Nom d'un département 


Identifiant d'un employé 


Nom et prénom d'un employé 


| SalEmp | Salaire d'un employé 


Situation d'un employé ('T': Titulaire; 'S': Stagiaire) | 





En s'appuyant sur les requêtes données ci-dessus, et pour chacune des propositions du tableau ci-dessous, 


répondre par la lettre (V) si la proposition est correcte ou par la lettre (F) dans le cas contraire. Justifier votre 


réponse par la clause de la contrainte correspondante utilisée dans la requête. 


Justification par la clause 
de la contrainte 
correspondante 
















La suppression d'un enregistrement de la table DEPARTEMENT 
entraine la suppression automatique des enregistrements qui lui 
correspondent de la table EMPLOYE. 


Il est possible d'insérer un nouvel enregistrement dans la table 
EMPLOYE dont l'identifiant de l'employé existe déjà dans cette table. 


Il est possible d'insérer un nouvel enregistrement dans la table 
EMPLOYE dont l'identifiant du département n'existe pas dans la table 
DEPARTEMENT. 


Il est possible d'insérer un nouvel enregistrement dans la table 
EMPLOYE dont le salaire est de 5000 Dinars. 
Il est possible d'insérer un nouvel enregistrement dans la table 


DEPARTEMENT dont le nom du département existe déjà dans cette 
table. 


Il est possible d'insérer un nouvel enregistrement dans la table 
EMPLOYE sans saisir le nom et le prénom de l'employé, | |-... 
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Exercice 2 (7 points) 


Soit la base de données intitulée "Gestion_Parkings" permettant de gérer, en ligne, un ensemble de parkings de 
voitures situés au centre ville. Elle est décrite par la représentation textuelle simplifiée suivante : 

VOITURE (ImmatVoit, CarVoit) 

PARKING (NumPark, NomPark, AdrPark, Capacite, TarifHeur) 

PLACEDISPO (NumPark#, NumPlace CodeDispo) 

STATION (NumPark#, NumPlacett, ImmatVoit#, DateStat, HeureEnt, HeureSort) 


== 
colonne 
Immatriculation d'une 
voiture 
Caractéristiques d'une 
voiture 





Description des colonnes des tables 


Nom de 
escrpion 
Tarif d'une heure de stationnement en dinars 


Numéro de place dans un parking 


CodeDispo | Code de disponibilité d'une place dans un 
parking('O' : Disponible /'N' : Non disponible) 















Numéro du parking 





Capacité du parking en 
nombre de places 
1. Sachant que cette base de données est accessible au public durant toute la journée, écrire les requétes SQL 
permettant d'afficher : 
a) la liste des parkings dont la capacité dépasse 150 places (nom, adresse, capacité et tarif d'une heure), 
triée par ordre croissant des noms. 


b) la liste des parkings (nom, adresse)ayant le tarif de stationnement le moins cher. 


c) le nombre de places disponibles, à n'importe quel moment, par parking. 


Page 2 sur 5 
Page 8 





2. Sachant que la voiture d'immatriculation "4444 Tu 144" a occupé la place numéro 25 du parking numéro 110 
le 15/06/2020 à 8h du matin et elle l'a quitté la même journée à 13h. Ecrire les requêtes SQL permettant: 


a) d'ajouter à la base de données, le stationnement de cette voiture et de mettre à jour la disponibilité de la 


b) de mettre à jour la base de données à la sortie de cette voiture du parking. 


3. Dans le but d'aider l'administrateur à mieux gérer la base de données, écrire les requêtes SQL permettant : 
a) d'ajouter un utilisateur identifié par User11 à la base de données et lui attribuer le mot de passe 
"PSw2020" 
b) d'attribuer à l'utilisateur crée précédemment, les droits d'insertion et de modification sur les tables 


VOITURE, PLACEDISPO et STATION. 


place qu'elle a occupée. 





Voir suite au verso & 
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Exercice 3 (8,5 points) 

On se propose d'implémenter une base de données permettant de gérer les analyses médicales au sein d'un 
laboratoire. 

La secrétaire d'accueil prend en charge le patient à travers une ordonnance médicale (ANNEXE A) pour 
enregistrer les analyses demandées par le médecin traitant. Toutes les informations qui sont relatives au 
médecin doivent être prises en charge dans cette base. 

S'il s'agit d'un nouveau patient, la secrétaire lui attribue un numéro de dossier unique et inscrit aussi toutes les 
données qui lui sont relatives, notamment son nom, son prénom, son âge, son genre et la date de création de 
son dossier. 

Après avoir effectué les prélèvements nécessaires pour les analyses demandées, ces prélèvements sont orientés 
pour l'examen selon le type de l'analyse. Sachant qu'il existe 4 types d'analyses de libellés (BIOCHIMIE; 
HEMATOLOGIE; BACTERIO-PARASITOLOGIE et IMMUNO-SEROLOGIE). 

Chaque analyse appartient à un type et est caractérisée entre autres par un nom, une unité et des valeurs 
normales (ANNEXE B). 

Les détails des résultats des différentes analyses d'un patient sont d'abord enregistrés puis lui sont communiqués 


via un bilan imprimé (ANNEXE B). 


Travail demandé : 
En se basant sur les annexes A et B et afin de concevoir cette base de données, on vous demande de : 


1) Reproduire le tableau ci-dessous et le remplir par la liste des colonnes groupées par sujet tout en 


indiquant pour chaque sujet son identifiant. 





2) En déduire la représentation textuelle de cette base de données tout en précisant les clés primaires et les 


clés étrangères. 
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ANNEXE A (Ordonnance médicale) 


Docteur Najmeddine SOULA 
MEDECINE GENERALE 


3, Av. Habib Bourguiba, Tunis 
Mobile : 88777666 Tél Fixe : 81777666 


Tunis, Le 27 Mai 2020 


Patient : Feirouz SAIDANE 


Analyses demandées : 


67, Av. Habib Bourguiba, Tunis 


Tél : 8155 78 86 


GLOBULES ROUGES 
HEMATOCRITE 

HEMOGLOBINE 

LEUCOCYTES 

GLYCEMIE 

CHOLESTEROL TOTAL- HDL- LDL 
TRIGLYCERIDES 

ACIDE URIQUE 

CREATININE 


ANNEXE B (Bilan d'analyses) 
LABORATOIRE D'ANALYSES MEDICALES 


Tunis, Le 28 Mai 2020 


Analyses 


GLOBULES ROUGES 
HEMATOCRITE 
HEMOGLOBINE 

VGM 

TGMH 

CCMH 
LEUCOCYTES 


Analyses 
GLYCEMIE 
CHOLESTEROL TOTAL 
CHOLESTEROL HDL CHOLESTEROL 
LDL 
TRIGLYCERIDES 
ACIDE URIQUE 
CREATININE 


Type d'analyse : HEMATOLOGIE 
Résultats / Unité 


4.42 10p6/mm° 
36.4 % 
12.1 g/dL 
82 um? 
27.4 pg 
33.2 g/dL 
7100 /mm° 


Type d'analyse : BIOCHIMIE 
Résultats / Unité 


0.94 g/L 
1.58 g/L 
0.31 g/L 
1.11 g/L 
0.89 g/L 
50 mg/L 
10 mg/L 
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Numéro du Bilan : 1269 

Date prélèvement : 27 Mai 2020 

N° Dossier : 12223 / 064 

Patient : Mme Feirouz SAIDANE 
Demandé par : Dr. Najmeddine SOULA 


Valeurs Normales 


(4 - 5.5) 
(35 - 47) 
(12 — 16) 
(82 - 98) 
(27 - 32) 
(32 - 36) 
(4000 — 10000) 


Valeurs Normales 


(0.7 - 1.10) 
(<2.20) 
(>0.55) 
(<1.40) 

(0.4 — 1.4) 

(30 - 70) 
(7-14) 





Section: N'd'necripton:: 7 Série... 
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Épreuve : Bases de données- Section : Sciences de l'informatique- Session de contrôle 2020 
Feuille à compléter par le candidat et à rendre avec sa copie. 


Exercice 1 (3,5 points) 


Pour chacun des tableaux ci-dessous, mettre une croix (X) dans la case qui correspond à la bonne 
proposition. 


















hi 






permet d'extraire les données d'une base afin de les imprimer 
permet de stocker des données d'une maniére structurée 


LS LEP A E E 

SC GS ECTS 

Co fo fs lon 
d'interrogation d'une base de données 

PD BE ne ll 
interagir avec la base de données 


c'est un sous ensemble de lignes d'une table 
c'est un sous ensemble de colonnes d'une table 


c'est un ensemble de données provenant de 
différentes tables 





l'information n'est pas accessible à tout le monde. 
Chaque utilisateur y accède selon les droits et les 


èges qui lui sont attribués 
l'utilisateur doit s'identifier par un login et un mot 
de passe avant d'accéder à une base de données 
c'est la cohérence, la fiabilité et la pertinence des 
données 
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Exercice 2 (8,5 points) 


La société "TV_SMART" assure à ses clients, la vente et le service après vente de télévisions 
intelligentes. Pour chaque vente, la société offre une période de garantie, en dehors de laquelle, la 
maintenance est payante. 
Afin de gérer les interventions de maintenance, le service après vente utilise la base de données 
simplifiée suivante: 

CLIENT (NumCIN, NomcCit, AdrCit, VilCit, TelCit) 

TV (NumTv, MarqTv, DateTv, DurTv, PrixTv, NumCIN#) 

TECHNICIEN (MatTec, NomTec, TelTec) 

INTERVENTION (Numint, Datelnt, NumTv#, MatTec#) 

PANNE (NumPan, DesPan, FraisRepPan, Numint# ) 


Description des colonnes 


Nom de la 
i Matricule du technicien 






























NumCiN Numéro de la carte d'identité PrixTv Prix de la télévision 
nationale du client 
NomTec Nom et prénom du technicien 


Nom et prénom du client 
Téléphone du technicien 


(Numint [numéro de intervention | 
Dateint [Date de intervention | 


Numéro de la panne 
Description de la panne 


FraisRepPan | Frais de réparation de la panne 


1) Afin d'apporter plus d'intégrité et de fiabilité à la base de données, l'administrateur se propose 
d'ajouter une contrainte portant sur la durée de garantie d'une télévision qui doit être comprise 


entre 1 et 5 ans. Ecrire la requête SQL permettant de prendre en compte cette contrainte. 
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2) 


3) 


4) 


5) 


Pour faciliter la gestion de la base de données, l'administrateur ajoute un utilisateur identifié 
par User2020 à la base de données avec le mot de passe "PSw2020", tout en lui attribuant les 
droits d'insertion, de suppression et de mise à jour sur la table INTERVENTION. Ecrire les 
requêtes SQL correspondantes. 

Pour les télévisions de marque SMTV ayant une durée de garantie égale à 2 ans, on se propose 
d'augmenter cette durée d'une année. Ecrire la requête SQL correspondante. 

Afin d'alléger le contenu de la base de données, l'administrateur se propose de supprimer de la 
base toutes les données relatives aux télévisions vendues avant le premier janvier 2010. Ecrire 
l'ensemble des requêtes SQL correspondantes. 

Ecrire les requêtes SQL permettant d'afficher: 

a) La liste de télévisions (marque et durée de garantie) ayant le prix le plus cher. 

b) la liste des descriptions des pannes et les frais de réparation respectifs pour 
l'intervention numéro 1015, triée par ordre décroissant des frais de réparation des 
pannes. 

c) la liste des interventions (numéro et date) effectuées le 10 Mai 2020, par le technicien 
portant le nom "Mohamed GHARBI", 

d) la liste des interventions (numéro et date) effectuées pour le client portant le nom 
"Ahmed MASMOUDI". 


Voir suite au verso æ 
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Exercice 3 (8 points) 
Une agence de voyages se propose d'implémenter une base de données permettant de gérer les 
réservations en ligne des chambres d'hôtels. 
Chaque client établi une réservation en remplissant successivement trois formulaires répartis en trois 
étapes : 

1% étape : Recherche des hôtels disponibles (ANNEXE A) 
Le client doit choisir la ville destination, la période de séjour exprimée par une date de début et une 
date de fin, le nombre de chambres ainsi que le nombre de personnes (adultes et enfants). 

2°"* étape : Choix d'un hôtel et réservation des chambres (ANNEXE B) 
Le client doit choisir l'hôtel, le type de la réservation (Petit Déjeuner, Demi Pension ou Pension 
Complète). L'affectation des numéros des chambres se fait lors de la réservation, selon la disponibilité 
de chaque catégorie de chambre (Single, Double, Suite, etc.). 
Sachant qu'un hôtel est caractérisé par un nom et une classe exprimée en nombre d'étoiles (*, **, ***, 
sees etes). 

3% étape : Saisie des informations et validation de la réservation (ANNEXE C) 
Le client doit saisir ses informations personnelles pour compléter la réservation. E 
N.B : Un client peut faire plusieurs réservations dans des périodes de séjour différentes et chaque 


réservation concerne un seul client. 


Travail demandé : 
En se basant sur les annexes A, B et C et afin de concevoir cette base de données, on vous demande de : 


1) Reproduire le tableau ci-dessous et le remplir par la liste des colonnes groupées par sujet tout 


en indiquant pour chaque sujet son identifiant. 





2) En déduire la représentation textuelle de cette base de données tout en précisant les clés 


primaires et les clés étrangères. 
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Annexe A : Recherche des hôtels disponibles 
crasas ver rincon 


, Période - ré ape 
ou 
6 Nult(s) 
as 


Nombra de chanmbre 


Nombre de personnes -——--—_———— 


O Petit Déjeuner © Demi Pension O Pension Complète 
Chambre1 © Singe O Double © Suite 
ChambreZ © Singe O Double © Suite 


Hôtel Maestro *** 


Type réservation 
O Petit Déjeuner @ Demi Pension © Pension Complète 


Chambre 1 © Singe @ Double © Triple 
ChambreZ O Singe O Double (A Triple 


Hôtel Le Roi *** 
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Signature des 
surveillants 
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Épreuve : Bases de données - Section : Sciences de l'informatique - Session de contrôle 2019 
Feuille à compléter par le candidat et à rendre avec sa copie 


Exercice 1 (2,5 points) 


A/ Pour chacune des propositions ci-dessous, compléter la colonne « Valide » par la lettre V si la 
proposition est correcte, ou par la lettre F dans le cas contraire. 


Pour ajouter des données à une table, on utilise des états. 


La commande DELETE permet d'effacer la structure d'une table. 


Dans une base de données, deux utilisateurs différents, peuvent avoir le 


même mot de passe. 


L'option WITH GRANT OPTION permet d'attribuer à des utilisateurs le droit de 
sauvegarde de la base de données. 





B/ Compléter les propositions suivantes, par le nom de la contrainte appropriée, qui peut être : de 


table, référentielle ou de domaine : 


1. La clause ON DELETE CASCADE est utilisée pour maintenir la contrainte 
NO e Ne RU A en cas de suppression. 

2. La clause CHECK est utilisée pour garantir la contrainte d’intégrité ............................... 
pour chaque valeur saisie d’une colonne. 

3. La clause PRIMARY KEY est utilisée pour assurer la contrainte d’intégrité 


A PR A LU RO EE aa lors de sa création. 
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Le sujet comporte 4 pages numérotées de 1/4 à 4/4. 
La page 1/4 est à remplir par le candidat et à rendre avec sa copie. 


Exercice 2 (8,5 points) 
Soit la base de données intitulée "Club_ Robotique" permettant à un club d'amateurs de 
robotique de gérer leurs activités. 
Cette base est décrite par la représentation textuelle simplifiée suivante : 
ROBOT (IdRob, NomRob) 
FABRICANT (IdFab, LibFab) 
COMPOSANT (CodeComp, LibComp, PoidsComp, PrixComp, IdFab#) 
MEMBRE (IdMemb, NomMemb, PreMemb) 


MONTAGE (IdRob#, CodeComp#, IdMemb#, DateMont) 


Description des colonnes des tables 


Description a EN | 


identifiant du robot 















Nom de la colonne 
IdRob 























NomRob Nom du robot q 
IdFab Identifiant du fabriquant des composants 
 LibFab Libellé du fabriquant des composants E 











CodeComp 





Code du composant monté | 








LibComp Nom du composant monté 








PoidsComp Poids du composant exprimé en grammes 































PrixComp x Prix du composant exprimé en dinars 

- IdMemb Identifiant du membre du club 
NomMemb Nom du membre du club ra 
PreMemb Prénom du membre du club 


DateMont 





Date du montage du composant 
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1. Ecrire une requête SQL permettant de créer la table MONTAGE en tenant compte de la 


description suivante : 















AR 


| Chaine de 5 caractères | 
_| Chaine de 5 caractères 
Chaine de 5 caractères 
Date POSTAR 











IdMemb 
DateMont ç 











N.B : La valeur de la colonne « DateMont » est obligatoire. 
2. Pour visualiser les images capturées par les robots, nous avons besoin d'un nouveau 
composant «Caméra vidéo». Ecrire une requête SQL, permettant d'ajouter ce composant avec 


les caractéristiques suivantes : 
















PoidsComp 


CodeComp 
___CO015 


__ LibComp 


PrixComp 
Caméra vidéo 


180.250 _ 








3. Pour encourager les activités du club, les fournisseurs accordent une réduction de 20% sur le prix 
des composants dont le libellé commence par « Diode LED ». Ecrire une requête SQL permettant 
de faire cette mise à jour. 

4. Pour alléger les robots, le responsable du club décide dans le futur, de n'acheter que des 
composants dont le poids ne dépasse pas 200 g. Ecrire une te SQL permettant d'ajouter 
cette contrainte sous le nom VP. | 

5. Ecrire les requêtes SQL permettant d'afficher : 

a. la liste nominative des fabricants de composants, triée par ordre alphabétique croissant. 

b. les nom et prénom des membres qui ont participé dans le montage du robot identifié par 
'R101”. 

c. le nombre de composants ayant comme libellé " Capteur de couleurs", montés pendant 
l’année 2018. 

d. le nom des robots dans lesquels on a monté le composant ayant comme libellé "Caméra 
infrarouge”. 

e. pour chaque robot, le montant total de son montage ainsi que le nombre total de 
composants montés. 

6. Pour faciliter la gestion de la base de données, l'administrateur ajoute un utilisateur identifié par 

U22 et lui attribue le mot de passe 'ROB2019". Ecrire la requête SQL correspondante. 

7. Pour sécuriser davantage la base de données, l'administrateur attribue à l'utilisateur U22, les 

droits d'insertion, de mise à jour et de suppression sur la table COMPOSANT, tout en lui permettant 


de transmettre le droit d'insertion aux autres utilisateurs. Ecrire les requêtes SQL correspondantes. 
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Exercice 3 (9 points) 


Pour être considérée comme "Ville_Intelligente", une ville doit satisfaire certaines conditions. 
Pour cela, une expérience est lancée dans une ville donnée. L'idée consiste à connecter quelques 
éléments (éclairage public, signalisation (feu) tricolore, surveillance vidéo, contrôle radar et collecte 
des ordures), en vue de les gérer à distance. 


Pour commencer, une équipe de topographes répertorie chaque voie urbaine (rue, avenue, 
route, boulevard, etc.) et lui fait correspondre un code unique et un nom de voie. 


Le parc des objets intelligents de la ville, est composé de conteneurs, lampadaires, feux 
tricolores, caméras et radars. Pour répertorier ces objets, on retient un identifiant et un descriptif. 


Afin d'alimenter en énergie les objets intelligents, on a recours à des panneaux solaires, placés 
sur des voies urbaines et pour lesquels on note, un descriptif de puissance et la voie sur laquelle ils 
se trouvent. On note, qu’un même panneau solaire peut alimenter un ou plusieurs objets intelligents, 
et qu’un même objet n’est alimenté que par un seul panneau. A titre d'exemple, on peut installer sur 
"le boulevard de la Culture et des Arts”, 4 lampadaires, 3 conteneurs et 1 feu tricolore, tous 
alimentés par un même panneau solaire. 


Les capteurs qui peuvent être installés sur les objets sont des minuteries, des capteurs de 
lumière, d'obstacle ou de mouvement. Ainsi, sur un même objet intelligent, on peut installer 
plusieurs capteurs différents. Par exemple, on peut installer sur un lampadaire, un capteur de 
mouvement et un capteur de lumière. 


Travail demandé : 
A. Afin de concevoir cette base de données, on vous demande de : 


Déterminer dans un tableau, la liste des colonnes (Nom de la colonne, Description et Type). 
2. Définir dans un autre tableau, la liste des identifiants des sujets nécessaires au 
développement de cette base. (Sujet, Nom de l’identifiant, Description et Type). 
3. Déduire la représentation textuelle de cette base de données tout en précisant les clés 


primaires et les clés étrangères. 


B. Afin de réduire le nombre de pannes des objets intelligents, dues à la défaillance d’un panneau 
solaire, le service technique de la municipalité décide de renforcer l'alimentation en énergie des 
objets intelligents. Dorénavant, ils seront alimentés par un ou plusieurs panneaux solaires. 
Réécrire la représentation textuelle de la base en tenant compte de cette nouvelle contrainte. 
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Exercice 1 (2,5 Points = 4 * 0.25pt + 3 * 0.5 pt) 





A. Pour chacune des propositions ci-dessous, compléter la colonne « Valide » par la lettre V si la 
proposition est correcte, ou par la lettre F dans le cas contraire. 


Pour ajouter des données à une table, on utilise des états. Es 
La commande DELETE permet d’effacer la structure d’une table. EN 


Dans une base de données, deux utilisateurs différents, peuvent avoir le même 


mot de passe. 
L'option WITH GRANT OPTION permet d'attribuer a des utilisateurs le droit de 
sauvegarde de la base de données. 


B. Compléter les propositions suivantes, par le nom de la contrainte appropriée, qui peut étre : de 





table, référentielle ou de domaine : 
1. La clause ON DELETE CASCADE est utilisée pour maintenir la contrainte 
d'intégrité référentielle en cas de suppression. 
2. La clause CHECK est utilisée pour garantir la contrainte d'intégrité de domaine pour 
chaque valeur saisie d'une colonne. 
3. La clause PRIMARY KEY est utilisée pour assurer la contrainte d'intégrité de table lors de 


sa création. 
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Exercice 2 (8.5 points) 
Soit la base de données intitulée "Club_Robotique" permettant à un club d'amateurs de 
robotique de gérer leurs activités. 
Cette base est décrite par la représentation textuelle simplifiée suivante : 
ROBOT (IdRob, NomRob) 
FABRICANT (IdFab, LibFab) 





COMPOSANT (CodeComp, LibComp, PoidsComp, PrixComp, IdFab+t) 
MEMBRE (IdMemb, NomMemb, PreMemb) 
MONTAGE (IdRob+t, CodeComp#, IdMemb+, DateMont) 


Description des colonnes des tables 












































Nom de la Description 
colonne 

IdRob Identifiant du robot 
NomRob Nom du robot 
IdFab Identifiant du fabriquant des composants 
LibFab Libellé du fabriquant des composants 
CodeComp Code du composant monté 
LibComp Nom du composant monté 
PoidsComp Poids du composant exprimé en grammes 
PrixComp Prix du composant exprimé en dinars 
IdMemb Identifiant du membre du club 
NomMemb Nom du membre du club 
PreMemb Prénom du membre du club 
DateMont Date du montage du composant 











1. Ecrire une requéte SQL permettant de créer la table MONTAGE en tenant compte de la 














description suivante : 1 pt 
Nom de la colonne Type 
IdRob Chaine de 5 caracteres 
CodeComp Chaine de 5 caractères 
IdMemb Chaine de 5 caractères 
DateMont Date 














N.B : La valeur de la colonne « DateMont » est obligatoire. 
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CREATE TABLE MONTAGE ( 

IDRob varchar(5) REFERENCES ROBOT (IDRob), 

CodeComp varchar (5) REFERENCES COMPOSANT (CodeComp), 
IDMemb varchar (5) REFERENCES MEMBRE (IDMemb), 
DateMont Date Not Null, 

CONSTRAINT PK PRIMARY KEY (IDRob, CodeComp, IDMemb)); 


2. Pour visualiser les images capturées par les robots, nous avons besoin d’un nouveau 
composant «Caméra vidéo». Ecrire une requête SQL, permettant d'ajouter ce composant 
avec les caractéristiques suivantes : 0.75 pt 





CodeComp LibComp PoidsComp | PrixComp IdFab 
C0015 Caméra vidéo 150 180.250 F234 


INSERT INTO COMPOSANT VALUES ('C0015', 'Caméra vidéo', 150, 180.250 , ‘F234’); 


























3. Pour encourager les activités du club, les fournisseurs accordent une réduction de 20% sur le 
prix des composants dont le libellé commence par « Diode LED ». Ecrire une requête SQL 
permettant de faire cette mise à jour. 

UPDATE COMPOSANT SET PrixComp =PrixComp*80% 0.75 pt 


WHERE LibComp Like “Diode LED %' ; 


4. Pour alléger les robots, le responsable du club décide dans le futur, de n’acheter que des 
composants dont le poids ne dépasse pas 200 g. Ecrire une requéte SQL permettant d'ajouter 
cette contrainte sous le nom VP. 

ALTER TABLE COMPOSANT 0.75 pt 


ADD CONSTRAINT VP CHECK PoidsComp <= 200; 


5. Ecrire les requétes SQL permettant d'afficher : 
a. la liste nominative des fabricants de composants, triée par ordre alphabétique croissant. 
SELECT LibFab 


FROM FABRICANT 0.75 pt 
ORDER BY LibFab ; 


b. les nom et prénom des membres qui ont participé dans le montage du robot identifié 


par'R101'. 
SELECT NomMemb, PreMemb 
FROM MEMBRE Mb, MONTAGE Mt 0.75 pt 
WHERE Mt.IdMemb = Mb.IdMemb 
AND IdRob = “R101”; 
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c. le nombre de composants ayant comme libellé" Capteur de couleurs", montés pendant 


l’année 2018. 
SELECT COUNT(*) 
FROM MONTAGE M, COMPOSANT C 
WHERE M.CodComp = C.CodComp 0.75 pt 
AND LibComp = ‘Capteur de couleurs’ 
AND DateMont >= ‘01/01/2018’ AND DateMont <="31/12/2018'; 


d. le nom des robots dans lesquels on a monté le composant ayant comme libellé "Caméra 


infrarouge". 
SELECT NomRob 
FROM Robot R, MONTAGE M, COMPOSANT C 
WHERE C.CodComp = M.CodComp 0.75 pt 
AND R.IdRob = M.IdRob 
AND LibComp = ‘Caméra infrarouge’ ; 


e. pour chaque robot, le montant total de son montage ainsi que le nombre total de 


composants montés. 


SELECT Sum(PrixComp), COUNT(CodComp) 

FROM COMPOSANT C, MONTAGE M 0.75 pt 
WHERE C.CodComp = M.CodComp 

GROUP BY IdRob ; 


6. Pour faciliter la gestion de la base de données, l'administrateur ajoute un utilisateur 
identifié par U22 et lui attribue le mot de passe 'ROB2019'. Ecrire la requête SQL 
correspondante. 

CREATE USER U22 0.5 pt 
IDENTIFIED BY “ROB2019'; 

7. Pour sécuriser davantage la base de données, l'administrateur attribue à l’utilisateur U22, 

les droits d'insertion, de mise à jour et de suppression sur la table COMPOSANT, tout en lui 


permettant de transmettre le droit d'insertion aux autres utilisateurs. Ecrire les requêtes SQL 


correspondantes. 
GRANT UPDATE, DELETE  O.5 pt GRANT INSERT 0.5 pt 
ON COMPOSANT ON COMPOSANT 
TO U22; TO U22 
WITH GRANT OPTION; 
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Exercice 3 (9 points) 





















































A. (6.5 pts) 
1. Liste des colonnes (1.5 pts = 6 * 0.25 avec -0.25 pt par erreur) 

Nom de la colonne Description Type 
CodeVoie Identifiant de la voie urbaine Texte/Entier 
NomVoie Nom de la voie urbaine Texte 
IdObj Identifiant de l’objet intelligent Texte/Entier 
DesObj Descriptif de l’objet intelligent Texte 
DesPan Descriptif de la puissance du Texte 

panneau solaire 
DesCap Descriptif du capteur Texte 
2. Liste des identifiants (1 pt = 4 * 0.25) 

Sujet ue a Description Type 
VOIE CodeVoie Identifiant de la voie urbaine Texte/Entier 
OBJET IdObj Identifiant de l’objet intelligent Texte/Entier 
PANNEAU IdPan Identifiant du panneau solaire Texte/Entier 
CAPTEUR IdCap Identifiant du capteur Texte/Entier 




















3. Représentation textuelle (4 pts ) 


VOIE (CodeVoie, NomVoie) 
PANNEAU (IdPan, DesPan, CodeVoie#) 
OBJET (IdObj, DesObj, IdPan#) 
CAPTEUR (IdCap, DesCap, IdObj#) 

B. (2.5 pts) 


VOIE (CodeVoie, NomVoie) 

PANNEAU (IdPan, DesPan, CodeVoie#) 
OBJET (IdObj, DesObj) 

CAPTEUR (IdCap, DesCap, IdObj#) 
ALIMENTER (IdPan#, IdObj#) 
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Exercice 1 : (3 points) 

Lors des tests préalables avant l'exploitation d'une base de données, nous relevons des anomalies. 
Pour chaque numéro d'anomalie, compléter la colonne "RÉPONSES" par la lettre correspondante 
à la fonction d'un S.G.B.D. non respectée. 


ANOMALIES RÉPONSES FONCTIONS 

















1 İl existe deux enregistrements r dime | à Manipulation 
* | même table avant le même identifiant des données 
L'application ne permet pas de ré PEM E E 
PE } ł P b Gestion des accès 
2. | à tous les besoins de recherche sur les - 
; concurrents 
données de la base ENE N 








Une partie des données de la base est 
3 perdue à la suite d'une coupure de 
courant 





Sécurité 
du fonctionnement 


A A 
Définition 


des données 















Des colonnes nécessaires á la 
4. description d'un sujet ne figurent pas 
dans la base 








Des données secrètes sont consultées 
par tous les utilisateurs de la base 


intégrité 







des données 












La mise à jour d'une même table peut se 
faire simultanément par deux 
utilisateurs de la base 


Confidentialité 
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Exercice 2 : (9 points) 


Soit la représentation textuelle simplifiée d'une base de données qui gère les annonces de ventes de 
véhicules publiées par des clients sur un site de ventes en ligne. 

CONSTRUCTEUR (IdConst, NomConst) 

MODELE (1dMod. NomMod, IdConst#) 

VEHICULE (ImmatVeh, PuisFisc, Energie, Couleur, IdMod#) 

VENDEUR (Id Vend, Email, Tel, NomReg) 

ANNONCE (RefAnn, DateAnn, Prix Vente, IdVend#, ImmatVeh#) 





Description des colonnes des tables 









RENTI 
Ni 








t 










: me i ` j D] 
CARO pe E NT o SEPT | 
> 
Vente 


IdVend Identifiant du vendeur 
Email du vendeur 


Numéro de téléphone du 
vendeur 


NomReg Nom de la région du vendeur 
Référence de l'annonce 


DateAnn Date de l'annonce 
Prix de vente du véhicule 


$ 


PA? 







Puissance fiscale du véhicule (4 : 4CV. 





5 : 5CV, 6 : 6CV, etc.) 


Energie du véhicule ('E' : Essence, 
'D' : Diesel, 'G': Gaz. 'H' : Hybride) 
Couleur du véhicule ('R' : Rouge, 


Couleur 'B' : Blanc, 'L' : Bleu, 'N' : Noir, etc.) 





Partie A : Écrire les requêtes SQL pour : 


1. créer la table MODELE avec la description suivante : 












3 VD CE 






Texte de 6 caractères Clé primaire 










NomMod 


Texte de 30 caractères i 
IdConst 


Obligatoire 





Texte de 4 caractères 





1 
Clé étrangère | 
RS 
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2. diminuer de 10 % les prix de vente des véhicules ayant une puissance fiscale supérieure ou 
égale à 6 chevaux (6CV). 

3. supprimer toutes les annonces effectuées avant l'année 2010. 

4. afficher la liste des annonces de véhicules (Nom du modéle, puissance fiscale, énergie, 
couleur et prix de vente) classée par ordre décroissant des prix de vente. 

5. afficher tous les noms distincts de modèles de véhicules roulant au DIESEL et dont le prix 
de vente est inférieur ou égal à 50000 Dinars. 


6. afficher, pour chaque modèle, son identifiant et le nombre d'annonces correspondant. 


Partie B: 
Après analyse de la structure de la base. il s'avère nécessaire de recourir à la création d'une nouvelle 
table décrite par : REGION (IdReg. Libelle). 
1. Nommer la contrainte d'intégrité à respecter pour prendre en parite l'ajout de cette table 
dans la base. 
2. Suite à la création de la table REGION par l'administrateur, des modifications devront être 
apportées sur une autre table de la base, 
a) Donner la nouvelle représentation textuelle de la table concernée. 


b) Écrire l'ensemble des requêtes SQL permettant ces modifications, 


Voir suite au verso 7 
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Exercice 3 : (8 points) 


Les prix Nobel sont des récompenses décernées chaque année à des lauréats. Ces prix sont attribués 


par catégorie, pour les travaux réalisés par ces lauréats. 


On se propose de créer une base de données qui gère l'historique des prix Nobel. Pour cela, on vous 


donne les règles de gestion suivantes : 


1. Ilexiste 6 catégories distinctes de prix Nobel : 
e Physique, 
e Chimie, 
+ Médecine ou physiologie, 
e Littérature, 
e Paix, 
e Economic. 
2. Chaque année, les prix sont attribués à un (ou plusieurs) lauréat(s) pour avoir réalisé une 
action déterminée, nommée "Objet" dans l'annexe. 
3. Chaque objet de prix Nobel est classé sous l'une des catégories présentées précédemment. 
4. Le pays désigne la nationalité officielle de chaque lauréat ou l'origine géographique de 
l'institution lauréate. 
Pour illustrer le dictionnaire des données qui devra être pris en compte dans la conception de la base 
de données, on donne en annexe, le tableau qui résume l'attribution des prix Nobel par catégorie 
pour les années 2015 et 2016 : L'année d'obtention. la catégorie du prix, l'objet du prix, le nom du 


(ou des) lauréat(s) et le pays officiel de rattachement du (ou des) lauréat(s). 


Travail demandé : 
Afin de concevoir cette base de données, on vous demande de : 


1. déduire la liste des colonnes (Nom de la colonne, description, type et sujet). 

2. dresser dans un autre tableau, la liste des colonnes représentant les identifiants des sujets 
dégagés dans la question précédente (Nom de l'identifiant, description, type ct sujet). 

3. donner une représentation textuelle de la base de données tout en précisant les clés 


primaires ct les clés étrangères. 
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Annexe : Tableau qui résume l'attribution 


pour les années 2015 


Découverte sur les oscillations de 
neutrinos qui démontre que les neutrinos ont 
une masse 


Physique 


Études mécanistiques de la réparation de 


Chimie l'ADN 


des prix Nobel (par catégorie) 
et 2016 


Takaaki Kajita Japon 














Médecine 
ou 
Physiologie 


Pour leurs travaux de recherche contre 
le paludisme 


2015 


Pour son « œuvre polyphonique, mémorial de 
la souffrance et du courage à notre époque » 


Littérature 


Pour leur succès dans la mission qui a abouti 
à la tenue des élections présidentielles et 
législatives ainsi qu'à la ratification de la 
nouvelle Constitution en 2014 


Pour son analyse de la consommation, de 


Economie |, pauvreté et du bien-être 








Pour leurs travaux sur les transitions des 


Physique phases topologiques dans la matière 


Pour la conception et la synthèse de machines 


Chimie S E 
molcculaires 


Physiologie 
ou 
médecine 


Pour ses recherches sur l'autophagic 
2016 


Création de nouvelles expressions poétiques 
dans la grande tradition de la chanson 
américaine 


Pour ses efforts en faveur du processus de 


Littérature 


de Colombie (FARC) 


Pour leurs contributions à la théorie des 
contrats 


Économie 
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paix avec les Forces Armées Révolutionnaires 


pe B, McDonald Canada 

A Tomas Lindahl o Suéde 3 
Paul L. Modrich | USA 
Aziz Sancar À Turquie 
William C. Campbell Arlande 


Satoshi Ómura 





Tu Youyou 
Svetlana Aleksievitch Russie 
LTDH Tunisic 
| UTICA Tunisie 
Conseil de l'Ordre National des |... | 
Tunisie 


Avocats 
















Angus Deaton 


David J, Thouless 





! Duncan Haldane Royaume-Uni 





PRIT ER ES 52 
John M. Kosterlitz Royaume-Uni 
Jean-Pierre Sauvage 


James Fraser Stoddart Royaume-Uni 








Bernard Lucas Feringa | Pays-Bas 


Yoshinori Ohsumi 


Bob Dylan 


Juan Manuel Santos Colombie 





USA 


Oliver Hart 


Bengt Holmström Finlande 
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Exercice 1 : (3 points = 6 * 0,5) 
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Exercice 2 : (9 points) (-0.25 par erreur si la commande SQL est correcte) 
Soit la représentation textuelle simplifiée d'une base de données qui gère les annonces de ventes de 


véhicules publiées par des clients sur un site de ventes en ligne. 


CONSTRUCTEUR (IdConst, NomConst) 

MODEL E (IdMod, NomMod, IdConst#) 

VEHICULE (ImmatVeh, PuisFisc, Energie, Couleur, Id Mod#) 
VENDEUR (IdVend, Email, Tel, NomReg) 

ANNONCE (RefAnn, DateAnn, PrixVente, Id Vend#, ImmatVeh#) 


Partie A : Écrire les requêtes SQL pour : (1 + 1 + 1 + 1 + 1 + 1 = 6 points) 


1. Créer la table MODELE avec la description suivante : 
CREATE TABLE MODELE 
(IdMod Varchar(6) PRIMARY KEY, 
NomMod Varchar(30) NOT NULL, 
IdConst Varchar(4) REFERENCES Constructeur(IdConst)); 


2. diminuer de 10 % les prix de vente des véhicules ayant une puissance fiscale supérieure ou 


égale à 6 chevaux (6CV). 


UPDATE Annonce a, Vehicule v 

SET PrixVente = PrixVente * 0.9 

WHERE a.ImmatVeh = v.ImmatVeh 
And PuisFisc >= 6 ; 


3. supprimer toutes les annonces effectuées avant l'année 2010. 


DELETE FROM Annonce 
WHERE DateAnn <= "31/12/2009" ; 


N.B. : On acceptera tout format de date valide. 


4. afficher la liste des annonces de véhicules (Nom du modèle, puissance fiscale, énergie, 
couleur et prix de vente) classée par ordre décroissant des prix de vente. 
SELECT NomMod, PuisFisc, Energie, Couleur, Prix Vente 
FROM Annonce A, Vehicule V, Modele M 
WHERE A.ImmatVeh = V.ImmatVeh 
AND V.IdMod = M.IdMod 
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ORDER BY PrixVente DESC; 
5. afficher tous les noms distincts de modèles de véhicules roulant au DIESEL et dont le prix 
de vente est inférieur ou égal à 50000 Dinars. 
SELECT DISTINCT (NomMod) 
FROM Modele M, Annonce A, Vehicule V 
WHERE A.ImmatVeh = V.ImmatVeh 
AND V.IdMod = M.IdMod 
AND Energie = 'D' 
AND PrixVente <= 50000; 


6. afficher, pour chaque modèle, son identifiant et le nombre d'annonces correspondant. 
SELECT IdMod, Count(RefAnn) 
FROM Annonce A, Vehicule V 
WHERE A.ImmatVeh = V.ImmatVeh 
GROUP BY IdMod; 


Partie B : (0,5 + 0,5 + 2 = 3 points) 
Après analyse de la structure de la base, 1l s'avère nécessaire de recourir à la création d'une nouvelle 
table décrite par : REGION (IdReg, Libelle). 


1. Nommer la contrainte d'intégrité à respecter pour prendre en compte l'ajout de cette table 
dans la base. 


Contrainte d'intégrité référentielle. 


2. Suite à la création de la table REGION par l'administrateur, des modifications devront être 
apportées sur une autre table de la base. 


a) Donner la nouvelle représentation textuelle de la table concernée. 
VENDEUR (I Vend, Email, Tel, IdReg#) 
b) Écrire l'ensemble des requêtes SQL permettant ces modifications. 


ALTER TABLE VENDEUR 
DROP COLUMN NomkReg; 


ALTER TABLE VENDEUR 
ADD COLUMN IdReg Varchar(3) REFERENCES REGION (IdReg); 


NB : attribuer 1 point si le candidat propose une réponse qui consiste à supprimer la table Vendeur 
avant de la créer á nouveau. 
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Exercice 3 : (8 points) 


1. déduire la liste des colonnes (Nom de la colonne, description, type et sujet). 


(0.25 * 5 = 1.25 pts) 







































































e Le champ AnneePrix peut figurer dans la table OBJET 


Nom de la colonne Description Type Sujet 
AnneePrix Année d'obtention du prix Numérique | Prix/Objet 
IntCat Libellé de la catégorie du prix Nobel Texte Categorie 
IntObj Libellé de l'objet du prix Nobel Texte Objet 
NomLaur Nom du lauréat Texte Laureat 
LibPays Libellé du pays du lauréat Texte Pays 
2. dresser dans un autre tableau, la liste des colonnes représentant les identifiants des sujets dégagés 
dans la question précédente (Nom de l'identifiant, description, type et sujet). 
(0.25 * 4 = 1 pt) 
Nom de l'identifiant Description Type Sujet 
CodeCat Code de la catégorie du prix Nobel Texte / Num | Categorie 
CodeOb; Code de l'objet du prix Nobel Texte / Num Objet 
IdLaur Identifiant du lauréat du prix Nobel Texte / Num Laureat 
CodePays Code du pays Texte / Num Pays 
3. donner une représentation textuelle de la base de données tout en précisant les clés primaires et 
les clés étrangères. 
CATEGORIE (CodeCat , IntCat ) 
PAYS (CodePays, LibPays) 
LAUREAT (IdLaur, NomLaur, CodePays#) 
OBJET (CodeObj, LibObj, CodeCat#) 
PRIX (AnneePrix, CodeObj+*, IdLaur#) 
Remarques: 


e L'année peut être définie en tant qu'objet à part: ANNEE (NumAn, AnneePrix) 





























Identification des tables 5 * 0.25 = 1.25 

Détermination des clés primaires 5 *0.25=1.25 

Détermination des clés étrangères 4*05=2 

Détermination des autres colonnes 5 * 0.25 =1.25 
Total | 5.75 points 
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Section :. ont o Eu AAA Signatures des 
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Nom et prénom : ... 


Date et lieu de naissance : ..... 





DE minime ci a a UM ee 


Le sujet comporte 3 pages numérotées de 1/3 à 3/3. 
Cette feuille doit être remise à la fin de P'épreuve. 


Exercice 1 : (4,5 points) 


La première colonne du tableau ci-après représente des actions à réaliser sur une base de données. 
On vous demande de : 

1. compléter la deuxième colonne du tableau par le nom de la commande SQL appropriée à 
l'action décrite. 

2. compléter la colonne "Langage SQL" en mettant une croix (X) dans la case du langage 


SQL appropriée. 


A ae 
OM | Commande SOL 
Supprimer une table 


Ajouter des données à une table 


Ajouter un utilisateur 


Supprimer des données d’une table 


Modifier les données d'une table 





> Ajouter des droits à un utilisateur 





N.B. : 
L.D.D. : Langage de Définition de Données 
L.M.D. : Langage de Manipulation de Données 
L.C.D. : Langage de Contrôle de Données 
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Exercice 2 : (7 points) 


Soit la représentation textuelle d'une base de données simplifiée qui gère les espèces végétales d'une 
pépinière. 
TYPEPLANTE (IdTyp. LibTyp) 
CATEGORIE (IdCat, LibCat) 
PLANTE (IdPlan, NomPlan, Couleur, Expo, PrixUnit, IdT yp#, IdCat#) 
PARCELLE (IdParc, Surface) 
PLANTER (IdParc#, IdPlan#, Ote) 








Description des colonnes des tables 















Cr 
Je! Po Y a Ce Gini a A is 
a DESA ption t auna 
$ AL O NON AUS 








Libellé du type de la plante 


LibTyp (Exemples : Verte, Grasse, Graminée, 
etc.) 


Identifiant de la catégorie de la plante 


Libellé de la catégorie de la plante 
LibCat (Exemples : Plante de jardin, Plante 
décorative, Plante médicinale, etc.) 


IdPlan Identifiant de la plante 





beenen ae DU 
X onn: # Eat | Prost LE 
x > la plante ('R' : Rouge, 
Couleur à $ = 
Couleur | B' : Blanc, 'V' : Vert, etc.) 
Exposition de la plante 
Expo (Exemples : 'O': Ombre, 
'M' : Mi-Ombre. 'S' : Soleil) 
Prix unitaire de la plante 
Identifiant de la parcelle 
Surface de la parcelle 
Qte Quantité de la plante dans une 
parcelle (en unités) 
1. afficher les noms des plantes de couleur rouge et dont l'exposition est Mi-Ombre. 


NomPlan Nom de la plante 





A. Écrire les requêtes SQL pour : 


2. afficher toutes les plantes (Nom, couleur et prix) de catégorie Plante de jardin’, 

3. afficher les noms par ordre alphabétique des plantes qui se trouvent sur la parcelle dont 
l'identifiant est 'PA10". 

4. mettre à jour la table concernée par la livraison de 1000 unités de plantes identifiées par le 


code 'PL55' à partir de la parcelle d'identifiant 'PA10S, 
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5. afficher par couleur (Couleur et quantité totale) des plantes disponibles en quantité totale 
supérieure ou égale à 100 unités. 
6. ajouter une contrainte d'intégrité de domaine permettant d'autoriser uniquement les valeurs 
‘0’, 'M' ou 'S' dans la colonne Expo de la table PLANTE. 
B. L'administrateur se propose de supprimer toutes les plantes dont le nom commence par 'Ja' et 
ayant comme libellé de type Grasse’. 
1. Écrire la requête SQL correspondante. 


2. Citer tous les cas possibles afin d'exécuter cette requête. 


Exercice 3 : (8,5 points) 


L'entreprise ENNAJDA se propose d'implémenter une base de données afin de gérer la vente et la 
pose de capteurs en matière de protection contre les incendies, les intrusions et les inondations. 
Toute activité commerciale de l'entreprise fait l'objet d'un contrat. 

Pour chacun de ses clients, la société ENNAJDA retient les informations suivantes : un code, une 
raison sociale et un numéro de téléphone. 

On note également, qu'un client peut avoir plusieurs locaux. Pour cela, chaque contrat, est identifié 
par un numéro. Il est établi à une date précise, et il spécifie pour chaque local, le ou les capteurs à 
installer. Chaque local, identifié par deux coordonnées GPS, est caractérisé par un numéro de 
téléphone. 

Pour chaque capteur, identifié par un code, on fixe un tarif et on définit un libellé qui peut être : 


incendie, intrusion ou inondation. 


Travail demandé : 
Afin de concevoir cette base de données. on vous demande de : 


1. déduire la liste des colonnes (Nom de la colonne, description, type et sujet). 
2. donner une représentation textuelle de la base de données tout en précisant les clés primaires 


et les clés étrangères. 
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Exercice 1 : (4,5 points = 6 * 0,5 + 6 * 0,25) 


























Action à réaliser Commande SQL LDD. Tangage © QL LCD. 
> Supprimer une table DROP TABLE X 
> Ajouter des données à une table INSERT X 
> Ajouter un utilisateur CREATE USER X 
> Supprimer des données d’une table DELETE X 
> Modifier les données d'une table UPDATE X 
> Ajouter des droits à un utilisateur GRANT X 























Exercice 2 : (7 points= 1.25 + 1.25 + 1.25 + 1 + 1 + 1 + 0.25) 


Soit la représentation textuelle d'une base de données simplifiée qui gère les espèces végétales d'une 
pépinière. 
TYPEPLANTE (IdTyp, LibTyp) 
CATEGORIE (IdCat, LibCat) 
PLANTE (IdPlan, NomPlan, Couleur, Expo, PrixUnit, IdT yp#, IdCat#) 
PARCELLE (IdParc, Surface) 
PLANTER (IdParc#, IdPlan#, Ote) 


A. Écrire les requêtes SQL pour : 


1. afficher les noms des plantes de couleur rouge et dont l'exposition est Mi-Ombre. 
SELECT NomPlan 
FROM Plante 
WHERE Couleur = 'R' 
AND Expo = 'M'; 
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afficher toutes les plantes (Nom, couleur et prix) de catégorie ‘Plante de jardin. 


SELECT NomPlan, Couleur, PrixUnit 
FROM Plante P, Categorie C 
WHERE P.IdCat = C.IdCat 

AND LibCat = 'Plante de jardin'; 


afficher les noms par ordre alphabétique des plantes qui se trouvent sur la parcelle dont 
l'identifiant est 'PA10'. 


SELECT NomPlan 

FROM Plante P, Planter PL 
WHERE P.IdPlan = PL.IdPlan 
AND IdParc = 'PA10' 

ORDER BY NomPlan; 


mettre à jour la table concernée par la livraison de 1000 unités de plantes identifiées par le 
code 'PL55' à partir de la parcelle d'identifiant 'PA105". 


UPDATE Planter SET Ote = Ote — 1000 
WHERE IdParc = 'PA105' AND IdPlan = 'PL55"; 


afficher par couleur (Couleur et quantité totale) des plantes disponibles en quantité totale 
supérieure ou égale à 100 unités. 


SELECT Couleur, SUM (Qte) Som 

FROM Plante P, Planter PL 

WHERE P.IdPlan = PL.IdPlan 

GROUP BY Couleur HAVING Som >= 100; 


ajouter une contrainte d'intégrité de domaine permettant d'autoriser uniquement les valeurs 
'O', 'M' ou 'S' dans la colonne Expo de la table PLANTE. 


ALTER TABLE Plante Add Constraint CHECK Expo IN ('O', 'M', 'S”); 


L'administrateur se propose de supprimer toutes les plantes dont le nom commence par 'Ja' et 
ayant comme libellé de type ‘Grasse’. 


1. 


DELETE P FROM Plante P, TypePlante T 
WHERE P.IdTyp = T.IdTyp 

AND P.NomPlan LIKE 'Ja%' 

AND T.LibTyp = 'Grasse'; 


Ou bien 

DELETE P.* FROM Plante P, TypePlante T | DELETE Plante FROM Plante, TypePlante 
WHERE P.IdTyp = T.IdTyp WHERE Plante.IdTyp = TypePlante.IdTyp 
AND P.NomPlan LIKE 'Ja%' AND Plante.NomPlan LIKE 'Ja%' 

AND T.LibT yp = 'Grasse'; AND TypePlante.LibTyp = 'Grasse'; 


2. Les cas possibles afin d'exécuter cette requête : 


e Soit la table Planter ne contient pas les plantes concernées. 
e Soit la contrainte d'intégrité référentielle de suppression en cascade (ON DELETE 
CASCADE) est définie dans la table Planter. 
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Exercice 3 : (8,5 points) 


1. Déduire la liste des colonnes (Nom de la colonne, description, type et sujet). (0.25 * 10 = 2.5 pts) 





















































Nom de la colonne Description Type Sujet 
CodeCl Identifiant du client Num / Texte Client 
RS Raison sociale Texte Client 
NumTel Numéro de téléphone du client Num / Texte Client 
NumCont Numéro du contrat Num / Texte Contrat 
DateCont Date du contrat Date / Heure Contrat 
GPSX Coordonnée X GPS du local Num / Texte Local 
f GPSY Coordonnée Y GPS du local Num / Texte Local 
Tel Numéro de téléphone du local Num / Texte Local 
CodeCap Code du capteur Num / Texte Capteur 
Tarif Prix du capteur Décimal Capteur 
Libelle Libellé du capteur Texte Capteur 








2. Donner une représentation textuelle de la base de données tout en précisant les clés primaires et 


les clés étrangères. 


CLIENT (CodeCl, RS, NumTel) 
CONTRAT (NumCont, DateCont) 
LOCAL (GPSX, GPSY, Tel, CodeCI#) 
CAPTEUR (CodeCap, Libelle, Tarif) 





LIGNECONTRAT (NumCont#, GPSX, GPSY#, CodeCap#) 


Remarque : Les coordonnées GPSX et GPSY d'un local peuvent être remplacées par une seule 

















colonne NUMGPS. 
Identification des tables 5 * 0.25 = 1.25 
Détermination des clés primaires 5 * 0.25 = 1.25 
Détermination des clés étrangères 4*0.5=2 
Détermination des autres colonnes 6*0.25=1.5 
Total | 6 points 
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Exercice 1 : (2 points) 
Dans un contexte de base de données, utiliser les termes ci-dessous pour compléter la première 


colonne du tableau en inscrivant devant chaque définition proposée le terme correspondant. 


Transactions, Pertinence, Disable, Contraintes, Attribut, Log, Enable, Enregistrement 


se 


Un fichier texte contenant l'historique des évènements relatifs aux 


accès à la base de données. 


Les règles qu’un SGBD applique automatiquement pour garantir 


la cohérence, la pertinence et la validité des données. 


Une propriété d'un sujet susceptible d'être enregistrée dans la base 


de données. 


Une option SQL permettant de désactiver une contrainte 


d'intégrité. 
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Exercice 2 : (3 points) 


Soit la base de données "Gestion Contrats" comportant la table CONTRAT. 
L'administrateur de cette base se propose de gérer les privilèges attribués aux utilisateurs User1, 


User2 et User3. 


Pour ce faire, il lance dans l'ordre chronologique les requêtes SQL suivantes : 


GRANT Select ON CONTRAT TO User] ; 

GRANT Insert, Update ON CONTRAT TO User2 WITH Grant Option ; 
GRANT ALL ON CONTRAT TO User3 ; 

GRANT Delete ON CONTRAT TO Public ; 

REVOKE Delete ON CONTRAT FROM User] ; 


1) Après l’exécution de toutes les requêtes ci-dessus, indiquer les droits attribués à chaque 


utilisateur sur la table CONTRAT en mettant une croix (X) dans les cases correspondantes. 





2) L'utilisateur User2 se propose de lancer les requêtes présentées dans le tableau ci-dessous. En 
tenant compte des droits attribués ou retirés précédemment, mettre une croix (X) devant chaque 


requête qui engendrera un message d'erreur. 


GRANT Update ON CONTRAT TO Userl 





GRANT Select ON CONTRAT TO Public ; 
GRANT Delete ON CONTRAT TO User! ; 
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Exercice 3 : (7 points) 


Soit la base de données simplifiée "Apréciations Films” permettant à un site de streaming 
de films en ligne de gérer les appréciations des internautes relatives aux films hébergés. 
Cette base de données est décrite par la représentation textuelle suivante : 
CATEGORIE(CodeCat, DesCat) 
FILM(NumFil, TitFil AnnFil, RealFil, ResFil, DurFil, NbVisFil, CodeCat#) 
INTERNAUTE (IdInt, Logint, PswInt, EmailInt) 
APPRECIATION (NumApp, NbEtoile, DateApp, ComApp, NumFil#, Idint# ) 


Description des colonnes 












[din | Identifiant de linternaute 
Login de l'internaute 
| Pswint | Mot de passe de linternaute 






Code de la catégorie du film 
Désignation de la catégorie du film 


Degat (Classique, Animation, Fiction... 
NumFil Numéro du film 































|Emaillnt | Email de linternaute | 
umApp Numéro de l’appréciation du film 
z Nombre d'étoiles attribué á un 
R film 
DatcApp 
DurFil Durée du film Coins Commentaire formulé par 


| NbVisFil Nombre de visualisations du film l'internaute sur un film 


1) Après avoir terminé la création de cette base de données, l'implémenteur s’est rendu compte 
qu’il a oublié de définir la contrainte d'intégrité référentielle relative à la colonne CodeCat de la 
table FILM. 


Ecrire une requête SQL permettant de définir cette contrainte d'intégrité. 


2) Afin de suivre les tendances des internautes, on se propose de récupérer un ensemble 
d'informations de la base de données du site. Écrire les requêtes SQL permettant d’afficher. 
a) la liste, triée dans l'ordre alphabétique croissant, des films (Titre) qui ne sont pas 


encore visualisés. 
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b) la liste des commentaires émis par l'internaute ayant pour login "Jad312". 

c) la liste sans redondance des films (Titre, Réalisateur, Résumé, Durée) ayant obtenu 5 
étoiles et dont la désignation de la catégorie est "Animation ". 

d) pour chaque film, son numéro et la moyenne des étoiles qui lui sont attribuées. 

3) Le suivi des appréciations des films, amène l'administrateur du site à constater que les films 
sortis avant l'année 1985 et qui n’appartiennent pas à la catégorie "Classique" n'intéressent 
pas les internautes. Pour alléger la base de données, il décide de supprimer ces films. 

Sachant que le code de la catégorie classique est "CL22", écrire une requête SQL qui permet 


de réaliser cette tâche. 


Exercice 4 : (8 points) 

Le directeur d'un établissement scolaire se propose d'implémenter une base de données 
simplifiée afin de gérer les sorties scolaires organisées au profit des élèves. 

Chaque élève peut participer à plusieurs sorties. Il est identifié par un matricule et est 
caractérisé par son nom, son prénom, sa date de naissance, son adresse, sa classe et le numéro de 
téléphone de son tuteur. 

Dans une sortie, une ou plusieurs étapes sont programmées. Chaque sortie est identifiée par 
un numéro et est caractérisée par le thème de la sortie, la date et l'heure de départ. 

Chaque étape d'une sortie correspond à la visite d'un site et elle est caractérisée par un 
numéro unique et l'heure de la visite. Le site à visiter est caractérisé par un code unique, une 
description, une adresse et une ville de localisation. Chaque ville est caractérisée par un code 


unique et un intitulé. 
Questions : 


Afin de concevoir cette base de données, on vous demande 


1) d'élaborer la liste des colonnes (Nom de la colonne, Description et Type). 
2) de donner une représentation textuelle de la base de données tout en précisant les clés 


primaires et les clés étrangères. 
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Session principale - Baccalauréat 2017 








Exercice 1 (2 points= 4 * 0,5 point) 




















Terme Définition 
Log Un fichier texte contenant l'historique des évènements relatifs aux accès à la base de données. 
; Les règles qu’un SGBD applique automatiquement pour garantir la cohérence, la pertinence 
Contraintes DAE 7 
et la validité des données. 
Attribut Une propriété d'un sujet susceptible d'être enregistrée dans la base de données. 
Disable Une option SQL permettant de désactiver une contrainte d'intégrité. 








Exercice 2 (3 points = 2,25 points + 0,75 point) 


Soit la base de données "Gestion_Contrats" comportant la table CONTRAT. 


L'administrateur de cette base se propose de gérer les privilèges attribués aux utilisateurs Userl, 
User2 et User3. 
Pour ce faire, il lance dans l'ordre chronologique les requêtes SQL suivantes : 


GRANT Select ON CONTRAT TO Userl ; 

GRANT Insert, Update ON CONTRAT TO User2 WITH Grant Option ; 
GRANT ALL ON CONTRAT TO User3 ; 

GRANT Delete ON CONTRAT TO Public ; 

REVOKE Delete ON CONTRAT FROM Userl ; 





1) Après l’exécution de toutes les requêtes ci-dessus, indiquer les droits attribués à chaque utilisateur 


sur la table CONTRAT en mettant une croix (X) dans les cases correspondantes. 

















Utilisateurs | Lecture Insertion Modification Suppression 
Userl X 
User2 X X X 
User3 X X X X 




















2) L'utilisateur User2 se propose de lancer les requêtes présentées dans le tableau ci-dessous. En 
tenant compte des droits attribués ou retirés précédemment, mettre une croix (X) devant chaque 
requête qui engendrera un message d'erreur. 





Réponse Requête 
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GRANT Update ON CONTRAT TO User] ; 
X GRANT Select ON CONTRAT TO Public ; 
X GRANT Delete ON CONTRAT TO Userl ; 




















Exercice 3 (7 points) 


Soit la base de données simplifiée "Apréciations_Films" permettant à un site de streaming de films 
en ligne de gérer les appréciations des internautes relatives aux films hébergés. 


Cette base de données est décrite par la représentation textuelle suivante : 


CATEGORIE (CodeCat, DesCat) 
FILM (NumFil, TitFil, AnnFil, RealFil, ResFil, DurFil, NbVisFil, CodeCat#) 
INTERNAUTE (IdInt, Logint, PswInt, Emaillnt) 


APPRECIATION (NumApp, NbEtoile, DateApp, ComApp, NumFil#, Idint# ) 
1) 


ALTER TABLE FILM 
ADD CONSTRAINT fk FOREIGN KEY (CodeCat) 
REFERENCES CATEGORIE (CodeCat) ; 

2) 


SELECT TitFil 
FROM FILM 
WHERE NbVisFil =0 
ORDER BY TitFil ; 


SELECT ComApp 

FROM APPRECIATION A, INTERNAUTE I 
WHERE A.ldint = 1.IdInt 

and LogINT = 'Jad312' ; 


SELECT DISTINCT TitFil, RealFil, ResFil, DurFil 
FROM FILM F, CATEGORIE C, APPRECIATION A 
WHERE (A.NumFil = E.NumFil) 

and (F.CodeCat = C.CodeCat) 

and (DesCat = 'Animation') 

and (NbEtoile = 5) ; 


SELECT NumFil, AVG(Nbetoile) 
FROM FILM 
GROUP BY NumHil ; 
3) 
DELETE FROM FILM 
WHERE (CodeCat <> 'CL22') 
AND (AnnFil <1985) ; 
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Exercice n°4 (8 points) 







































































1) 

Nom de la colonne Description Type 
NumSor Numéro de la sortie Numérique ou texte 
ThemSor Thème de la sortie Texte 
DatSor Date de la sortie Date 
HeurSor Heure de départ de la sortie Heure 
NumEtp Numéro de l'étape Numérique 
HeurEtp Heure programmée de l'étape Heure 
CodSit Code du site Numérique ou texte 
DescSit Description du site Texte 
AdrSit Adresse du site Texte 
MatElv Matricule de l'élève Numérique ou texte 
NomElv Nom de l'élève Texte 
PreElv Prénom de l'élève Texte 
DatNai Date de naissance de l'élève Date 
AdrElv Adresse de l'élève Texte 
ClasElv Classe de l'élève Texte 
TelElv Numéro de téléphone du tuteur de l'élève Numérique ou texte 
CodeVil Code de la ville Numérique ou texte 
IntVil Intitulé de la ville Texte 

2) 


ELEVE (MatElv, NomElv, PreElv, DatNai, AdrElv, ClasElv, TelElv) 


SORTIE (NumsSor, ThemSor, DatSor, HeurSor) 
ETAPE (NumEtp, NumSor#, HeurEtp, CodSit#) 
SITE (CodSit, DescSit, AdrSit, CodeVil#) 
VILLE (CodeVil, IntVil) 

PARTICIPANTS (NumSor#, MatElv#) 
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Signatures des 
surveillants 
Nom et prénom : 


Date et lieu de naissance : 


Le sujet comporte 4 pages numérotées de 1/4 à 4/4. 
Cette feuille doit être remise à la fin de l’épreuve. 


Exercice 1 : (3 points) 


Dans un contexte de base de données et pour chacune des propositions suivantes, mettre dans la 


case correspondante la lettre V si la réponse est correcte ou la lettre F dans le cas contraire. 


1) L’extraction d’un sous ensemble de colonnes d’une tabje correspond à une : 
jointure 
projection 


sélection 


2) En SQL, pour automatiser la modification de la valeur d’une clé étrangère dans une table fille à 
la suite de la modification de la valeur de la clé primaire de la table mère correspondante, on 
ajoute la clause ON UPDATE CASCADE à ja définition de la : 

D clé primaire dans la table mère 
clé étrangère dans la table fille 


mM clé primaire dans la table fille 


3) L'intégrité d'une base de données consiste a : 


|] 


a garantir la cohérence des données 
| définir un ensemble de règles (valeur, référence, unicité) 


définir les données d'une façon unique 


4) En SQL, ja clause GROUP BY permet : 


de grouper, selon un critère, des lignes d'une ou de plusieurs tables 
de grouper, selon un critère, des colonnes d'une ou de plusieurs tables 
d'effectuer des calculs sur un groupe de résultats à l'aide des fonctions d'agrégat 
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Exercice 2 : (9 points) 


Soit la base de données simplifiée "Gestion Rallye" permettant à une ligue d'amateurs de 


rallye moto de gérer les différentes étapes d'un rallye. 
Cette base de données est décrite par la représentation textuelle suivante : 


PILOTE (NumPil, NomPil, PrePil, DateNaisPil) 

VILLE( CodeVil, NomVil) 

ETAPE (NumEtp, CodeVilDep#, CodeVilArr#, DisEtp, DateEtp, CodeType# ) 
TYPE _ ETAPE (CodeType, DesType) 

TEMPS (NumEtp#, NumPil#, TempsReal) 





Description des colonnes 

















CodeVilDep Code de la ville de départ d une étape 
CodeVilArr 


DisEtp 


Numéro du pilote 




















FNomPil 


PrePil 
DateNaisPil 


Nom du pilote Code de la ville d’arrivée d'une étape 








Prénom du pilote Distance parcourue dans une étape 




















Date de naissance du pilote DateEtp 







Date prévue d'une étape 


































| CodeVil Code de la ville CodeType Code du type d'une étape 
| Nom de la ville Désignation du type d'une étape 
Nom Vil DesType 
(Montagne, Asphalte et Désert) 
| NumEtp Numéro de l’étape TempsReal Temps réalisé par un pilote dans une étape 
N.B. : 


- Toutes les tables de la base de données sont déjà créées. 
- La table TYPE ETAPE a été créée avec une contrainte de domaine nommée CD définie sur 
la colonne DesType et permettant de limiter les désignations seulement aux valeurs suivantes : 


"Montagne"," Asphalte" et "Désert". 
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1) Suite aux travaux d'entretien entamés sur l'itinéraire de l'étape numéro 5 ayant comme désignation 
du type de l'étape "Asphalte", la ligue décide de changer cet itinéraire par un autre de type 


"Forêt". 
Pour prendre en charge cette modification, écrire les requêtes SQL permettant : 


a) de supprimer la contrainte de domaine nommée CD. 

b) d'ajouter à la table TYPE ETAPE une nouvelle contrainte de domaine sur la colonne 
DesType permettant d'accepter seulement les désignations suivantes : "Montagne", 
"Asphalte", "Désert" et "Forêt". 

c) d'insérer dans la table TYPE ETAPE la ligne suivante : 








d) de mettre à jour la colonne CodeType à "T4" pour l'étape numéro 5. 


2) Afin de permettre aux amateurs de suivre de près le déroulement du rallye, la ligue se propose de 


mettre à leur disposition un ensemble d'informations. 
Ecrire les requêtes SQL permettant d'afficher : 


a) la liste des étapes programmées pour la journée du "01/06/2017" 
b) la liste des pilotes (nom et prénom) participants dans l'étape numéro 7 triée par ordre 
croissant selon leurs temps réalisés. 
c) Le total des distances parcourues dans toutes les étapes qui sont programmées dans la 
montagne. 
d) pour chaque étape du rallye, le meilleur temps réalisé. 
3) Pour éviter le changement des résultats des étapes du rallye, l'administrateur de la base de données 
décide de retirer de l'utilisateur User1 le droit de modification sur la table TEMPS. 
Sachant que l'utilisateur User1 est déjà créé et bénéficie de tous les droits, écrire une requête SQL 


permettant d'effectuer cette tâche. 


Voir suite au versa 
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Exercice 3 : (8 Points) 


Une entreprise pharmaceutique se propose de concevoir une base de données simplifiée afin dé 


gérer l’accès des employés aux zones sensibles d’un laboratoire dédié à la recherche. 


Le laboratoire est divisé en un ensemble de zones. Chaque zone est identifiée par un code et 
elle est caractérisée par un intitulé, un digicode d’accès (mot de passe) et un niveau de sécurité. Ce 


dernier est identifié par un numéro et il est caractérisé par une description. 


Une zone est composée d'un ensemble de locaux. Chaque local, appartenant à une zone, est 


identifié par un numéro et il est caractérisé par une description (Bureau, Couloir, Ascenseur). 


Un employé est identifié par un matricule, et il est caractérisé par son nom, son prénom, sa date de 


naissance, son adresse et son numéro de téléphone. 


Pour chaque employé, on définit les accès autorisés aux zones. Chaque accès est caractérisé par 


une heure d’entrée et une heure de sortie. 
Questions : 
Afin de concevoir cette base de données, on vous demande : 


1. d'élaborer la liste des colonnes (Nom de la colonne, Description et Type). 
2. de donner une représentation textuelle de la base de données tout en précisant les clés primaires 


et les clés étrangères. 


| Page Ade J 


Corrigé : Base de Données 
Section : Sciences de l’informatique 
Session de contrôle 2017 





Exercice 1 (3 points= 0.25 point *12) 


1) L’extraction d’un sous ensemble de colonnes d’une table correspond à une : 














F | jointure 
V | projection 
F | sélection 








2) En SQL, pour automatiser la modification de la valeur d’une clé étrangère dans une table fille à 


la suite de la modification de la valeur de la clé primaire de la table mère correspondante, on ajoute 


la clause ON UPDATE CASCADE à la définition de la : 





F 


clé primaire dans la table mère 





V 


clé étrangère dans la table fille 





F 





clé primaire dans la table fille 








3) L'intégrité d'une base de données consiste à : 





V 





V 





F 











garantir la cohérence des données 
définir un ensemble de règles (valeur, référence, unicité) 


définir les données d’une façon unique 


4) En SQL, la clause GROUP BY permet : 





V 





F 





V 











de grouper, selon un critère, des lignes d'une ou de plusieurs tables 
de grouper, selon un critère, des colonnes d'une ou de plusieurs tables 


d'effectuer des calculs sur un groupe de résultats à l'aide des fonctions d'agrégat 


Exercice 2 (9 points) 


Soit la base de données simplifiée ""Gestion_ Rallye" permettant à une ligue d'amateurs de rallye 


moto de gérer les différentes étapes d'un rallye. 


Cette base de données est décrite par la représentation textuelle suivante : 
PILOTE (NumPil, NomPil, PrePil, DateNaisPil) 
VILLE (CodeVil, NomVil) 
ETAPE (NumEtp, CodeVilDep#, CodeVilArr#, DisEtp, DateEtp, CodeType#) 
TYPE_ETAPE (CodeType, DesType) 
TEMPS (NumEtp#, NumPil#, TempsReal) 
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1) Suite aux travaux d'entretien entamés sur l'itinéraire de l'étape numéro 5 ayant comme désignation 
du type de l'étape "Asphalte", la ligue décide de changer cet itinéraire par un autre de type "Forêt". 
Pour prendre en charge cette modification, écrire les requêtes SQL permettant: 


a) de supprimer la contrainte de domaine nommée CD. 


ALTER TABLE TYPE_ETAPE 
DROP CONSTRAINT CD; 
b) d'ajouter à la table TYPE_ETAPE une nouvelle contrainte de domaine sur la colonne 
DesType permettant d'accepter seulement les désignations suivantes : "Montagne", 


"Asphalte", "Désert" et "Forét". 
ALTER TABLE TYPE_ETAPE 


ADD CONSTRAINT CHECK (DesType in (Montagne','Asphalte','Désert', 'Forét”)); 
c) d'insérer dans la table TYPE_ETAPE la ligne suivante : 





CodeType DesType 
T4 Forét 

















INSERT INTO TYPE_ETAPE (CodeType, DesType) 
VALUES ('T4', 'Forét') ; 
d) de mettre à jour la colonne CodeType à « T4 » pour l’étape numéro 5. 


UPDATE ETAPE 
SET CodeType='T4' 
WHERE NumEtp=s ; 


2) Afin de permettre aux amateurs de suivre de près le déroulement du rallye, la ligue se propose de 
mettre à leur disposition un ensemble d’informations. 
Ecrire les requêtes SQL permettant d’afficher : 


a) la liste des étapes programmées pour la journée du « 01/06/2017 ». 


SELECT * 
FROM ETAPE 
WHERE DateEtp ="20170601' ; 
b) La liste des pilotes (nom et prénom) participants dans l’étape numéro 7 triée par ordre 
croissant selon leurs temps réalisés. 


SELECT NomPil, PrePil 
FROM PILOTE P, TEMPS T 
WHERE P.NumPil = T.NumPil 
AND NumEtp = 7 

ORDER BY TempsReal ; 
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c) Le total des distances parcourues dans toutes les étapes qui sont programmées dans la 
montagne. 
SELECT SUM(DisEtp) 
FROM ETAPE E, TYPE_ETAPE T 
WHERE E.CodeType = T.CodeType 
AND DesType = "Montagne ; 


d) pour chaque étape du rallye, le meilleur temps réalisé. 
SELECT NumEtp, MIN(TempsReal) 


FROM TEMPS 
GROUP BY NumEtp ; 


3) Pour éviter le changement des résultats des étapes du rallye, l’administrateur de la base de données 
décide de retirer de l’utilisateur User1 le droit de modification sur la table TEMPS. 
Sachant que l’utilisateur Userl est déjà créé et bénéficie de tous les droits, écrire une requête SQL 


permettant d’effectuer cette tâche. 


REVOKE UPDATE ON TEMPS 
FROM User! ; 


Exercice 3 (8 points) 


1) Liste des colonnes : 





















































Nom de la colonne Description Type 
CodZon Code de la zone Numérique ou texte 
IntZon Intitulé de la zone Texte 
DigZon Digicode de la zone Texte 
NumNiv Numéro du niveau de sécurité Numérique ou texte 
DesNiv Description du niveau de sécurité Texte 
NumLoc Numéro du local Numérique ou texte 
DesLoc Description du local Texte 
MatEmp Matricule de l'employé Numérique ou texte 
NomEmp Nom de l'employé Texte 
PreEmp Prénom de l'employé Texte 
DatnEmp Date de naissance de l'employé Date 
AdrEmp Adresse de l'employé Texte 
TelEmp Numéro de téléphone de l'employé Numérique ou texte 
HeuEnt Heure d'entrée autorisée à une zone Date 
HeuSor Heure de sortie autorisée d'une zone Date 

















2) Représentation textuelle : 
ZONE (CodZon, IntZon, DigZon, NumNiv#) 
NIVEAU_SECURITE (NumNiv, DesNiv) 
LOCAL (NumLoc, DesLoc, CodZon#) 
EMPLOYE (MatEmp, NomEmp, PreEmp, DatnEmp, AdrEmp, TelEmp) 
ACCES (MatEmp#, CodZon#, HeuEnt, HeuSor) 
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Cette feuille doit être remise à la fin de l'épreuve. 


Exercice 1 : (3 points) 


Dans un contexte de base de données, valider chacune des propositions suivantes en mettant la 
lettre V si elle est correcte ou la lettre F si elle est fausse. 


1) La mise à jour d’une table peut être réalisée par une opération : 
p p 


d'insertion de données 
de modification de données 


de suppression de données 


2) En langage SQL, la modification de la structure d’une table est effectuée avec la commande : 


UPDATE 
MODIFY 
ALTER TABLE 
3) En langage SQL, la clause ADD permet l’ajout de : 


colonnes à une table 
contraintes d’intégrité 
tables dans une base de données 


4) En langage SQL, la commande REVOKE fait partie du : 


Langage de Définition de Données (LDD) 
Langage de Manipulation de Données (LMD) 


Langage de Contrôle de Données (LCD) 
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Exercice 2 : (9 points) 


Le ministère de l’intérieur se propose de concevoir une base de données pour gérer les affaires 
régionales et locales du pays. Le territoire tunisien est décomposé en 6 régions de planification 
(Nord-Est, Nord-Ouest, Centre-Est, Centre-Ouest, Sud-Est et Sud-Ouest), en 24 gouvernorats et en 
264 délégations. 


La représentation textuelle de cette base de données simplifiée est décrite comme suit : 


REGION (CodeReg, LibReg) 
GOUVERNORAT (CodeGouv, LibGouv, DateGouv, CodeReg#) 
DELEGATION (CodeDel, LibDel, DateDel, PopDel, SupDel, CodeGouv#) 





Texte 3 


Due f 





1) Dresser la représentation graphique de cette base de données. 

2) En se référant à la description des colonnes indiquée ci-dessus, écrire la requête SQL 
permettant de créer la table DELEGATION, sachant que les deux tables REGION et 
GOUVERNORAT sont déjà créées. 

3) Pour apporter plus d’efficacité à cette base de données, l’administrateur décide d’ajouter une 
contrainte sur la colonne SupDel de la table DELEGATION afin de vérifier la validité de 
sa valeur qui doit être strictement positive. 


Écrire la requête SQL permettant de prendre en compte cette contrainte. 


Page 2/5 


Page 56 





4) 


5) 


6) 


L’administrateur de cette base de données se propose d’ajouter un nouvel utilisateur 

identifié par 'USER2016' et ayant comme mot de passe 'BDINT2016'. 

Écrire les requêtes SQL permettant d’ : 

a- ajouter cet utilisateur pour accéder à cette base de données. 

b- attribuer à l’utilisateur USER2016 déjà crée en a), les droits de modification et de 
suppression sur la table DELEGATION. 

L’administrateur charge l’utilisateur USER2016 d’ajouter une nouvelle délégation qui vient 

d’être créée par le ministère. Bien que la requête tapée soit correcte, toutefois un message 

d’alerte s’affiche. 

a- Expliquer pourquoi ? 

b- Comment peut-on résoudre ce problème ? 

Écrire les requêtes SQL permettant d’afficher : 

a- la liste des gouvernorats (code et libellé) créés après le "01/01/2000" et triés par ordre 
croissant des libellés. | 

b- la liste des délégations (code, libellé, population et superficie) du gouvernorat ayant 
comme libellé 'Manouba'. 

c- pour chaque gouvernorat, son code, le nombre de délégations qui le composent, sa 


superficie totale et sa population totale. 
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Exercice 3 : (8 points) 


Un Bureau Régional d’Emploi décide d’implémenter une base de données simplifiée afin de gérer 
les demandes d’emploi présentées par des demandeurs et les offres d’emploi lancées par des 
entreprises cherchant à satisfaire leurs besoins en ressources humaines. 
Pour ce faire, soient les deux formulaires présentés ci-après pour prendre en charge les 
demandes relatives aux demandeurs d’emploi et aux offres des entreprises : 
- formulaire de demande d’emploi rempli par un diplômé (voir Annexe A) 
- formulaire d’offre d’emploi rempli par une entreprise (voir Annexe B) 
De même, on propose les règles de gestion suivantes qui doivent être respectées pour concevoir 
cette base de données : 
- un demandeur d'emploi cherche un poste de travail via un seul diplôme d'études. 
- un diplôme d'études peut être présenté par plusieurs demandeurs d'emploi. 
- à une date donnée et pour un diplôme spécifié, une entreprise peut lancer une seule offre 
d'emploi. 
- une offre d'emploi est lancée par une seule entreprise et elle est caractérisée par un nombre 
de postes supérieur ou égal à un. 
- l'affectation d'un ou plusieurs demandeurs d'emploi à une offre est validée par sa date 
d'affectation. 


- un demandeur d'emploi peut être affecté à une ou plusieurs offres différentes. 


Travail demandé : 


Appliquer la démarche de détermination de la structure d’une base de données pour déduire ła 
représentation textuelle de la base relative à ce système d’information tout en précisant la 


description de chacune des colonnes utilisées dans un tableau comme indiqué ci-dessous. 
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Formulaire de demande d’emploi rempli par un jeune diplômé 


(Annexe A) 


N° CIN : | 01234567 | 


Nom : | Ben Foulen Prénom : | Foulen 


Date de naissance : | 20-03-1990 Téléphone : | 22334455 


Adresse : | 12, Rue de la République, 7000 KEBILI 
Diplôme : | Licence en Informatique | Date d’obtention du diplôme : | 30-06-2012 
Référence de l'offre : | 1550 Date d’affectation à Poffre : | 12-01-2016 





Formulaire d’offre d’emploi rempli par une entreprise 


(Annexe B) 


Référence de l'offre : | 1550 Date de Poffre : | 10-12-2015 
Diplóme : | Licence en Informatique 


Nom de l’entreprise : | SOFT INFO Téléphone : | 75757575 
Adresse de l’entreprise : | Rue 14 Janvier, KEBILI ¡Nombre de poste(s) : 





N.B. : Tout objet figurant dans les annexes A et B doit être identifié. 
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Exercice 1 : (0.25 * 3) * 4 = 3 points 


Dans un contexte de base de données, valider chacune des propositions suivantes en mettant la 
lettre V si elle est correcte ou la lettre F si elle est fausse. 


1) La mise à jour d’une table peut être réalisée par une opération : 





V | d’insertion de données 





V | de modification de données 











V | de suppression de données 





2) En langage SQL, la modification de la structure d’une table est effectuée avec la commande : 
F | UPDATE 

F | MODIFY 

V | ALTER TABLE 




















3) En langage SQL, la clause ADD permet l’ajout de : 





V | colonnes à une table 





V | contraintes d’intégrité 





F | tables dans une base de données 











4) En langage SQL, la commande REVOKE fait partie du : 





F | Langage de Définition de Données (LDD) 





F | Langage de Manipulation de Données (LMD) 











V | Langage de Contrôle de Données (LCD) 
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Exercice 2 : (9 points) 1.5 + 1.5 + 0.5 + (2 * 0.75) + (0.5 + 0.5) + (3 * 1) = 9 points 


Le ministère de l’intérieur se propose de concevoir une base de données pour gérer les affaires 
régionales et locales du pays. Le territoire tunisien est décomposé en 6 régions de planification 
(Nord-Est, Nord-Ouest, Centre-Est, Centre-Ouest, Sud-Est et Sud-Ouest), en 24 gouvernorats et en 
264 délégations. 


La représentation textuelle de cette base de données simplifiée est décrite comme suit : 
REGION (CodeReg, LibReg) 
GOUVERNORAT (CodeGouv, LibGouv, DateGouv, CodeReg#) 
DELEGATION (CodeDel, LibDel, DateDel, PopDel, SupDel, CodeGouv#) 






































1) Dresser la représentation graphique de cette base de données. 0.5*3= 1.5 points 
REGION 1 
CodeReg 
LibReg GOUVERNORAT 
CodeGouv 1 
LibGouv DELEGATION 
E DateGouv CodeDel 
CodeReg LibDel 
DateDel 
PopDel 
SupDel 
i CodeGouv 











2) (1.5 points) 
CREATE TABLE DELEGATION ( 


CodeDel Varchar(3) PRIMARY KEY, 

LibDel Varchar(40) NOT NULL, 

DateDel Date, 

PopDel Decimal(9,3), 

SupDel Decimal(6,3), 

CodeGouv Varchar(2), 

CONSTRAINT FK1 FOREIGN KEY (CodeGouv) REFERENCES GOUVERNORAT 
(CodeGouv)); 


3) ALTER TABLE DELEGATION ADD CONSTRAINT CA CHECK SupDel > 0; (0.5 pt) 
4) 





a- CREATE USER 'USER2016' IDENTIFIED BY 'BDINT2016'; (0.75 pt) 
b- GRANT UPDATE, DELETE ON DELEGATION TO USER2016; (0.75 pt) 
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5) 
a- L'utilisateur n’a pas le droit d’ajouter des données dans la table DELEGATION (car on lui 
a attribué uniquement les droits de modification et de suppression). (0.5 pt) 
b- Attribuer à l’utilisateur USER2016 le droit d’insertion sur la table DELEGATION. (0.5 pt) 


6) Écrire les requêtes SQL permettant d’afficher : 
a- (1 point) 
SELECT CodeGouv, LibGouv 
FROM GOUVERNORAT 
WHERE DateGouv > ‘01/01/2000 
ORDER BY LibGouv; 


b- (1 point) 
SELECT CodeDel, LibDel, PopDel, SupDel 
FROM DELEGATION D, GOUVERNORAT G 
WHERE D.CodeGouv = G.CodeGouv 
AND LibGouv = 'Manouba'; 


c- (1 point) 
SELECT CodeGouv, COUNT(CodeDel), SUM(SupDel), SUM(PopDel) 
FROM DELEGATION 
GROUP BY CodeGouv; 


Exercice 3 : (8 points) 


e Représentation textuelle 
DEMANDEUR (CinDem, NomDem, PreDem, DnaDem, TelDem, AdrDem, CodeDip#, 
DatDipDem) (1 point) 


DIPLOME (CodeDip, LibDip) (0.5 point) 
OFFRE (RefOff, DateOff, CodeDip#, NbrPostOff, CodeEnt#) (0.75 point) 
ENTREPRISE (CodeEnt, NomEnt, AdrEnt, TelEnt) (0.75 point) 





AFFECTATION (CinDem#, RefOff#, DateAff) (0.75 point) 
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e Description des colonnes (0.25*17 = 4.25 points) 






























































Nom de la colonne Description 
CinDem Numéro de la carte d’identité du demandeur d’emploi 
NomDem Nom du demandeur d’emploi 
PreDem Prénom du demandeur d’emploi 
DnaDem Date de naissance du demandeur d’emploi 
TelDem Numéro de téléphone du demandeur d’emploi 
AdrDem Adresse du demandeur d’emploi 
DatDipDem Date d’obtention du diplôme du demandeur d’emploi. 
CodeDip Code du diplôme 
LibDip Libellé du diplôme (Exp : Licence en informatique...) 
RefOff Référence de l’offre d’emploi lancée par une entreprise 
DateOff Date d’élaboration de l’offre d’emploi lancée par une entreprise 
NbrPostOff Nombre de poste(s) de l’offre d’emploi 
CodeEnt Code de l’entreprise 
NomEnt Nom de l’entreprise 
AdrEnt Adresse de l’entreprise 
TelEnt Numéro de téléphone de l’entreprise 
DateAff Date d’affectation du demandeur d’emploi à une offre 
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RÉPUBLIQUE TUNISIENNE 
MINISTÈRE DE L'ÉDUCATION 
JH R 


Section : Sciences de l'informatique 


EXAMEN DU BACCALAURÉAT | Coefficient: 1.5 | 





SAO NA om N' d'insertion. A Signatures des 
surveillants 
A El le à 


Date et lieu de naissance : ccoo... 


Le sujet comporte 4 pages numérotées de 1/4 à 4/4. 
Cette feuille doit être remise à la fin de l'épreuve. 





Exercice 1 : (3 points) 


Pour chacune des propositions citées dans le tableau ci-dessous, compléter la colonne « Validité » 
par la lettre V si la proposition est correcte ou la lettre F si elle est fausse. En cas où la proposition 
est fausse, apporter une correction. 


Une table peut comporter plusieurs clés 
étrangères. 


L’authentification rend impossible le 
déchiffrement d’une base de données. 


Le Langage de Définition de Données 
(LDD) permet de manipuler le contenu 
d’une base de données. 


Le résultat d’une sélection est un sous- 
ensemble de lignes d’une table. 
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NE RIEN ECRIRE ICI 





Exercice 2 : (10 points) 


Soit la base de données simplifiée intitulée "Gestion_Infirmiers' permettant de gérer les 
affectations des infirmiers au niveau des différents services d’un hôpital universitaire nouvellement 
crée. 


Cette base est décrite par la représentation textuelle suivante : 


SERVICE (CodeSer, LibSer, TelSer) 
INFIRMIER (Numinf, NomInf, Prelnf, SalInf, CodeSer#) 


Table : INFIRMIER Table : SERVICE 


A E CA 0 
pisan paola : 
20 || so |Pésiare | 77222114 | 
MEJO 


TERRO PTI TNA m 




























|: 20 
7 
0 
BALDI 


1) Analyser le contenu de chacune des tables INFIRMIER et SERVICE afin de compléter le 
tableau ci-dessous en identifiant les deux anomalies détectées ainsi que la contrainte 
d’intégrité non respectée. 








Pade 652 [4 





2) 


3) 


4) 


5) 


6) 


NE RIEN ECRIRE ICI 





Afin d’appliquer d’autres contraintes d’intégrités sur cette base de données et pour chacune 
des propositions suivantes, mettre une croix (X) devant la bonne réponse : 


a) Pour attribuer la valeur initiale zéro à la colonne Sallnf lorsqu’aucune valeur ne lui a 
été affectée, on doit utiliser l’option : 


| | DEFAULT | | DISTINCT | | NULL 


b) Pour garantir une valeur positive à la colonne Sallnf, on doit utiliser option : 


[_ | NOT NULL | | DEFAULT | | CHECK 


c) Pour garantir l obligation de la saisie de la colonne LibSer, on doit utiliser l’option : 


[| UNIQUE [_ ] NOT NULL | ] DEFAULT 


Pour faciliter le contact avec les infirmiers en cas d'urgence, il s’est avéré nécessaire 


d’enrichir cette base de données par le numéro de téléphone personnel de chaque infirmier 
intitulé Tellnf ayant 8 caractères. 


Écrire une requête SQL permettant de réaliser cette tâche. 
Un nouveau service identifié par le code 60, portant le libellé ‘Urgence’ et ayant comme 
numéro de téléphone "77222116" vient d’être crée dans cet hôpital. A ce service, un nouvel 


infirmier a été affecté et AR les informations suivantes : 


; af a 


1649823 | BEN AMOR 670.368 


Ecrire les requétes SQL permettant de prendre en charge cette mise á jour. 





Pour satisfaire les besoins du nouveau service nouvellement crée en 4), l’infirmier identifié 
par le numéro 1648215 est muté à ce service. 

Ecrire la requête SQL permettant de prendre en charge cette mise à jour. 

Écrire les requêtes SQL permettant d’afficher : 

a- la liste des services (code, libellé et téléphone) triée par ordre croissant des libellés. 

b- la liste des infirmiers (numéro, nom et prénom) affectés au service ayant comme 


libellé "Cardiologie". 


.€- pour chaque service, son code et le nombre d’infirmiers qui lui sont affectés. 
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Exercice 3 : (7 points) 
Dans le cadre de l’amélioration de la qualité du système éducatif tunisien, le ministère de 
l’éducation décide de lancer une chaîne télévisée éducative. 


L” administration de cette chaîne se propose d'implémenter une base de données simplifiée afin de 
gérer la diffusion de ses différentes émissions durant la journée. 


Chaque émission est identifiée par un code et caractérisée par un nom, un type d’émission et elle 
traite une matière enseignée pendant une durée de transmission bien déterminée. De même, une 
émission est animée par un seul animateur et diffusée une ou plusieurs fois à des dates et à des 
heures différentes. 


Tout type d'émission est identifié par son code et il est défini par son libellé (Leçon, Documentaire, 
Débat, Compétition). 


Chaque matière est identifiée par un code et elle est caractérisée par une désignation (Informatique, 
Mathématiques, Technologie, Economie, Sciences de la Vie & de la Terre Su 


Un animateur est identifié par un matricule et il porte un nom, un prénom, une date de naissance, un 
numéro de téléphone et une adresse. De même, il peut animer plusieurs émissions. 
Travail demandé : 


Appliquer la démarche de détermination de la structure d’une base de données pour déduire la 


représentation textuelle de la base relative à ce système d’information tout en précisant la 


description de chacune des colonnes utilisées dans un tableau comme indiqué ci-dessous. 


- Nom dela colonne | 
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RÉPUBLIQUE TUNISIENNE | Épreuve : Bases de Données 
MINISTÈRE DE L'ÉDUCATION | 
E 
EXAMEN DU BACCALAURÉAT | Durée : 2H Coefficient : 1.5 


SESSION 2016 Session de contróle 








Section : Sciences de l'informatique 


















































Section rarase nine N° d'inscription : .......................... Série : Signatures des 
surveillants 
NOM et pr iii 
Date et lieu de naissance: ren donnera ace Ne 
IN A a iia 
Le sujet comporte 4 pages numérotées de 1/4 à 4/4. 
Cette feuille doit être remise à la fin de l’épreuve. 





Exercice 1 : (3 points) 


Pour chacune des propositions citées dans le tableau ci-dessous, compléter la colonne « Validité » 
par la lettre V si la proposition est correcte ou la lettre F si elle est fausse. En cas où la proposition 
est fausse, apporter une correction. 


Proposition Joie Correction apportée 
P (V/F) PP 


Une table peut comporter plusieurs clés 
étrangères. 


L’authentification rend impossible le 
déchiffrement d’une base de données. 


(LDD) permet de manipuler le contenu 
d’une base de données. 


Le résultat d’une sélection est un sous- 
ensemble de lignes d’une table. 


Le Langage de Définition de Données = 
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Exercice 2 : (10 points) 





Soit la base de données simplifiée intitulée "Gestion Infirmiers" permettant de gérer les 
affectations des infirmiers au niveau des différents services d’un hôpital universitaire nouvellement 


crée. 


Cette base est décrite par la représentation textuelle suivante : 


SERVICE (CodeSer, LibSer, TelSer) 
INFIRMIER (Numinf, NomInf, Prelnf, Sallnf, CodeSer#) 





















































Table : INFIRMIER Table : SERVICE 
NumiInf NomiInf Prelnf | Salinf CodeSer CodeSer LibSer TelSer 

1542458 | ABIDI Fadoua 780.368 40 10 Cardiologie 77222111 
1221221 | TOUNSI Amel 1200.125 20 20 Radiologie 77222112 
2145487 | BEJI Yemen 890.524 10 30 Maternité 77222113 
1221221 | SAIDI Chahd 898.585 20 40 Pédiatrie 77222114 
1552845 | HAJI Rayen 750.021 30 

1648215 | BALDI Emna 1002.857 50 


1) Analyser le contenu de chacune des tables INFIRMIER et SERVICE afin de compléter le 
tableau ci-dessous en identifiant les deux anomalies détectées ainsi que la contrainte 


d’intégrité non respectée. 


Anomalie détectée Contrainte d’intégrité non respectée 
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2) Afin d’appliquer d’autres contraintes d’intégrités sur cette base de données et pour chacune 
des propositions suivantes, mettre une croix (X) devant la bonne réponse : 


a) Pour attribuer la valeur initiale zéro à la colonne Sallnf lorsqu’aucune valeur ne lui a 
été affectée, on doit utiliser l’option : 


DEFAULT DISTINCT NULL 






































b) Pour garantir une valeur positive à la colonne SalInf, on doit utiliser l’option : 





























NOT NULL DEFAULT CHECK 











c) Pour garantir l’obligation de la saisie de la colonne LibSer, on doit utiliser l’option : 











UNIQUE NOT NULL DEFAULT 





























3) Pour faciliter le contact avec les infirmiers en cas d’urgence, il s’est avéré nécessaire 
d’enrichir cette base de données par le numéro de téléphone personnel de chaque infirmier 
intitulé TelInf ayant 8 caractères. 


Écrire une requête SQL permettant de réaliser cette tâche. 
4) Un nouveau service identifié par le code 60, portant le libellé 'Urgence' et ayant comme 
numéro de téléphone ‘77222116 vient d’être crée dans cet hôpital. A ce service, un nouvel 


infirmier a été affecté et ayant les informations suivantes : 





Numinf Nominf Prelnf Salinf CodeSer TelInf 
1649823 BEN AMOR Walid 670.368 60 40366688 





























Ecrire les requétes SQL permettant de prendre en charge cette mise á jour. 
5) Pour satisfaire les besoins du nouveau service nouvellement crée en 4), l’infirmier identifié 
par le numéro 1648215 est muté à ce service. 
Ecrire la requête SQL permettant de prendre en charge cette mise à jour. 
6) Écrire les requêtes SQL permettant d’afficher : 
a- la liste des services (code, libellé et téléphone) triée par ordre croissant des libellés. 
b- la liste des infirmiers (numéro, nom et prénom) affectés au service ayant comme 
libellé "Cardiologie. 


c- pour chaque service, son code et le nombre d’infirmiers qui lui sont affectés. 


Page 3 / 4 
Page 70 


NE RIEN ECRIRE ICI 





Exercice 3 : (7 points) 
Dans le cadre de l’amélioration de la qualité du système éducatif tunisien, le ministère de 
l’éducation décide de lancer une chaîne télévisée éducative. 


L’administration de cette chaîne se propose d’implémenter une base de données simplifiée afin de 
gérer la diffusion de ses différentes émissions durant la journée. 


Chaque émission est identifiée par un code et caractérisée par un nom, un type d’émission et elle 
traite une matière enseignée pendant une durée de transmission bien déterminée. De même, une 
émission est animée par un seul animateur et diffusée une ou plusieurs fois à des dates et à des 
heures différentes. 


Tout type d'émission est identifié par son code et il est défini par son libellé (Leçon, Documentaire, 
Débat, Compétition...). 


Chaque matière est identifiée par un code et elle est caractérisée par une désignation (Informatique, 
Mathématiques, Technologie, Economie, Sciences de la Vie & de la Terre ...). 


Un animateur est identifié par un matricule et il porte un nom, un prénom, une date de naissance, un 
numéro de téléphone et une adresse. De même, il peut animer plusieurs émissions. 

Travail demandé : 

Appliquer la démarche de détermination de la structure d’une base de données pour déduire la 
représentation textuelle de la base relative à ce système d’information tout en précisant la 


description de chacune des colonnes utilisées dans un tableau comme indiqué ci-dessous. 


Nom de la colonne Description 
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RÉPUBLIQUE TUNISIENNE 


MINISTÈRE DE L'ÉDUCATION Durée : 2 h 
LES urée : 


EXAMEN DU BACCALAUR ÉAT Rss 
SESSION 2015 oefficient : 1,5 


Section : Sciences de l'informatique Session principale 





Le sujet comporte 8 pages numérotées de 1/8 a 8/8. 
Les réponses doivent être rédigées sur ces mêmes feuilles qui doivent être remises à la fin de l’épreuve. 


Exercice 1 : (5 points) 


D 


Pour chacune des propositions suivantes, encadrer l’un des termes proposés entre parenthèses afin 


d’avoir le bon sens des phrases. 


a) 


b) 


c) 


d) 


e) 


8) 


Une (information, base de données, fiche) peut être définie comme une collection de données 


structurées et enregistrées ensemble sans redondances. 
L’intégrité (de domaine, référentielle, de table) correspond à un ensemble de valeurs admissibles. 


Le langage de (définition, contrôle, manipulation) de données permet de définir les permissions 


accordées aux différents utilisateurs de la base de données. 


L'opération de (jointure, projection, sélection) consiste à extraire un sous-ensemble de colonnes 


d’une table. 


La commande SQL (UPDATE, MODIFY, ALTER TABLE) permet de modifier la structure d’une 
table existante. Il est ainsi possible d’ajouter, de supprimer ou de modifier une ou plusieurs 


colonnes existantes. 


Les (états, formulaires, requêtes) correspondent à des résultats d’interrogation destinés à être 
imprimés. 
(La traçabilité, La confidentialité, L’authentification) consiste à s’assurer de l’identité d’un 


utilisateur avant de lui donner l’accès à une base de données (login, mot de passe, ...). 
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ID Soit la représentation graphique suivante d’une base de données simplifiée représentant la gestion 
médicale dans un centre hospitalier. 








Medicament Consultation Medecin 


Y Code Medic Y Num_Consuit - Y Mot Med 
Libelte Date Consuit Aj Hom_Med 
Mat_Med 

Mat_Pat 




















Patient 


Y Num_Consuit Y Mat_Pat 
Y Code Medic Nom_Pat 
Nb_Pnses 




















1) Proposer une représentation textuelle de la base de données présentée ci-dessus. 


2) En se référant a la représentation graphique présentée ci-dessus, cocher la bonne réponse pour chacune 


des questions suivantes : 
























































a) Un patient peut-il effectuer plusieurs consultations ? Non Oui 

b) Un médecin peut-il recevoir plusieurs patients durant la méme consultation ? Oui 
Non 

c) Peut-on prescrire plusieurs médicaments dans une méme consultation ? Non Oui 

d) Deux médecins différents peuvent-ils prescrire le méme médicament ? Non Oui 




















Exercice 2 : (7 points) 


Une société immobilière se propose d’implémenter une base de données permettant la gestion 
de location de ses appartements à travers ses différentes agences réparties sur tout le territoire du pays. 
Cette base de données est composée de cinq tables (CLIENT, AGENCE, IMMEUBLE, 
APPARTEMENT, LOUER) décrites par les requêtes suivantes : 
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CREATETA BLE CLIENT ( varchar(8) CREATE TABLE AGENCE ( 


NumCIN PRIMARY KEY, IdAgence  varchar(3) PRIMARY KEY, 
NomClient varchar(30) NOT NULL, NomAgence varchar(30) NOT NULL, 
GenreClient varchar(1), AdrAgence varchar(50), 

AdrClient varchar(50), TelAgence  varchar(8)) ; 


TelClient varchar(8) NOT NULL) ; 








CREATE TABLE IMMEUBLE ( 
Codelmmeuble  varchar(3) PRIMARY KEY, 
Nomimmeuble  varchar(20) NOT NULL, 
AdrImmeuble varchar(50), 
IdAgence varchar(3) REFERENCES AGENCE ON DELETE CASCADE) ; 





CREATE TABLE APPARTEMENT ( 


Codelmmeuble varchar(3), 
NumAppart int(2), 
NumEtage int(2), 


PRIMARY KEY (Codelmmeuble, NumAppart), 
FOREIGN KEY (Codelmmeuble) REFERENCES IMMEUBLE ON DELETE CASCADE) ; 





CREATE TABLE LOUER ( 
NumCIN varchar(8), 
Codelmmeuble varchar(3), 
NumAppart int(2), 
DateLoc date, 
LoyerMensuel decimal(6,3) CHECK (LoyerMensuel > 0)) ; 





ALTER TABLE LOUER ADD CONSTRAINT CpLouer PRIMARY KEY (NumCIN, Codelmmeuble, 
NumAppart, DateLoc); 








ALTER TABLE LOUER ADD ( 

CONSTRAINT CeLouerl FOREIGN KEY (NumCIN) REFERENCES CLIENT (NumCIN) ON DELETE 
CASCADE, 

CONSTRAINT CeLouer2 FOREIGN KEY (Codelmmeuble) REFERENCES IMMEUBLE (Codelmmeuble), 
CONSTRAINT CeLouer3 FOREIGN KEY (Codelmmeuble, NumAppart) REFERENCES APPARTEMENT 
(Codelmmeuble, NumAppart)); 





Description des colonnes des tables 
























































Done Description de la colonne Nom de la colonne Description de la colonne 
colonne 
NumCIN N° de la carte d’identité du client TelAgence N° de téléphone de l’agence 
NomClient Nom du client Codelmmeuble Code de l’immeuble 
GenreClient so T m DEGN P MERGE NomImmeuble Nom de l’immeuble 
?F° : Féminin) 
AdrClient Adresse du client AdrImmeuble Adresse de l’immeuble 
TelClient N° du téléphone du client NumAppart Numéro de l’appartement 
IdAgence Identifiant de l’agence NumEtage Numéro de l’étage de l’appartement 
NomAgence Nom social de l’agence DateLoc Date de location de l’appartement 
AdrAgence Adresse de l’agence LoyerMensuel Montant du loyer mensuel 
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1) À partir de la description ci-dessus des tables, compléter le tableau suivant afin de déterminer la liste 
des liens entre les tables. 





Table mère Table fille Clé primaire Clé étrangère 























2) Donner la représentation textuelle correspondante à la description des tables ci-dessus. 


3) La colonne « GenreClient » de la table CLIENT ne peut prendre que les valeurs °M?’ ou ’F’. Écrire 


une requête SQL permettant de prendre en compte cette contrainte. 


Le sujet comporte 8 pages numérotées de 1/8 à 8/8. 
Les réponses doivent être rédigées sur ces mêmes feuilles qui doivent être remises à la fin de 
l'épreuve. 


4) Le 23/04/2015, un nouveau client vient de louer l’appartement N° 5 de l’immeuble ayant le code *120” 
avec un montant mensuel de 300 Dinars. Écrire une requête SQL permettant de prendre en compte ce 
client dans la base de données sachant qu’il possède les informations suivantes : 


NumCIN NomClient GenreClient AdrClient TelClient 
01234567 Ali Wafi M Tunis 79123345 





























5) Écrire une requête SQL permettant d’augmenter de 5% tous les loyers mensuels dont la location est 


faite avant le ‘01/01/2010’. 
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7) Écrire les requêtes SQL permettant d’afficher : 


a) le nombre d’appartements de chaque immeuble sous le format indiqué ci-après. 





Code Immeuble Nombre d’appartements 

















Exercice 3 : (8 points) 


Le stockage en ligne est l’un des multiples services du « Cloud Computing » recouvrant l’ensemble des 
solutions de stockage distant. En effet, vos données, au lieu d’être stockées sur vos disques durs ou 
mémoires, sont disponibles sur des serveurs distants qui sont accessibles par Internet et gérés par des 
prestataires (appelés aussi fournisseurs Cloud). Chacun des prestataires est identifié par un matricule 


et est caractérisé par un nom, une adresse et un numéro de téléphone. 


Les serveurs, d’un prestataire donné, possèdent chacun une adresse IP unique, un DNS, une fréquence du 


processeur et une capacité de stockage. 


Les prestataires fournissent chacun des offres à leurs clients. Pour chaque offre, on trouve un code, un 


slogan sous forme d’un texte, une capacité de stockage, un prix forfaitaire annuel et une taille maximale 
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par fichier. Pour s’abonner chez un prestataire, un client doit choisir l’une des offres fournies en 
fonction de ses besoins puis signer un contrat. Il doit mentionner son nom, son prénom, son adresse et 


son numéro de téléphone avant qu’un identifiant unique ne lui soit automatiquement attribué. 


Un client peut signer plusieurs contrats pour des offres différentes. Chaque contrat est identifié par une 


référence unique, une date de début et une période de validité exprimée en nombre de mois. 


Questions : 
On se propose d’implémenter une base de données simplifiée permettant la gestion des prestataires Cloud. 
Pour cela, on vous demande : 

1) d’élaborer la liste des colonnes (nom de la colonne, description, type de données, taille, sujet). 


2) de déduire la liste des tables. 


3) de donner la liste des liens entre les tables. 


4) d’en déduire une représentation textuelle de la base de données. 
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Exercice 1 : (5 points = 1,75 + 3,25) 
I. Pour chacune des propositions suivantes, encadrer l’un des termes proposés entre des parenthèses 
afin d’avoir le bon sens des phrases. 

a) Une (information, base de données, fiche) peut être définie comme une collection de 
données structurées et enregistrées ensembles sans redondances. 

b) L’intégrité (de domaine, référentielle, de table) correspond à un ensemble de valeurs 
admissibles. 

c) Le langage de (définition, contrôle, manipulation) de données permet de définir les 
permissions accordées aux différents utilisateurs de la base de données. 

d) L’opération de (jointure, projection, sélection) consiste à extraire un sous-ensemble de 
colonnes d’une table. 

e) La commande SQL (UPDATE, MODIFY, ALTER TABLE) permet de modifier la 
structure d’une table existante. Il est ainsi possible d’ajouter, de supprimer ou de modifier 
une ou plusieurs colonnes existantes. 

f) Les (états, formulaires, requêtes) correspondent à des résultats d’interrogation destinés à 
être imprimés. 

g) (La traçabilité, La confidentialité, L’authentification) consiste à s’assurer de l’identité 
d’un utilisateur avant de lui donner l’accès à une base de données (login, mot de passe, ..). 

II. Soit la représentation graphique d’une base de données simplifiée représentant la gestion médicale dans 
un centre hospitalier. 

1) Proposer une représentation textuelle de la base de données. 

MEDICAMENT (Code _Medic, Libelle) 

MEDECIN (Mat_Med, Nom_Med) 

PATIENT (Mat_Pat, Nom_Pat) 

CONSULTATION (Num_Consult, Date_Consult, Mat_Med#, Mat_Pat#) 
PRESCRIPTION (Num_Consult#, Code _Medic#, Nb_Prises) 

2) En se référant sur la représentation graphique présentée ci-dessus, cocher la 

bonne réponse pour chacune des questions suivantes : 
a. Un patient peut-il effectuer plusieurs consultations ? [XJOui 
b. Un médecin peut-il recevoir plusieurs patients dans la même consultation?  [kINon 
c. Peut-on prescrire plusieurs médicaments dans une même consultation ? Oui 
d. Deux médecins différents peuvent-ils prescrire le même médicament ? Oui 
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Exercice 2 : (7 points = 1,25 + 1,25 + 0,75 + 1,00 + 0,75 + 0,75 + 1,25) 
1) À partir de la description ci-dessus des tables, compléter le tableau suivant afin de déterminer la liste 


des liens entre les tables. 








Table mère Table fille Clé primaire Clé étrangère 
AGENCE IMMEUBLE IdAgence IdAgence 
IMMEUBLE APPARTEMENT | Codelmmeuble Codelmmeuble 
CLIENT LOUER NumCIN NumCIN 
IMMEUBLE LOUER Codelmmeuble Codelmmeuble 
APPARTEMENT | LOUER Codelmmeuble,NumAppart | Codelmmeuble, NumAppart 




















2) En déduire la représentation graphique de la structure de la base de données. 


CLIENT (NumCIN, NomClient, GenreClient, AdrClient, TelClient) 
AGENCE (IdAgence, NomAgence, AdrAgence, TelAgence) 
IMMEUBLE (Codelmmeuble, NomImmeuble, AdrImmeuble, IdAgence#) 
APPARTEMENT (Codelmmeuble#, NumAppart, NumEtage) 
LOUER (NumCIN#, Codelmmeuble#, NumAppart#, DateLoc, LoyerMensuel) 
3) La colonne « GenreClient » de la table CLIENT ne peut prendre que les valeurs °M? ou °F". Écrire une 
requête SQL permettant de prendre en compte cette contrainte. 
ALTER TABLE CLIENT ADD CONSTRAINT CHECK GenreClient In M’; F’); 


4) Le 23/04/2015, un nouveau client vient de louer l’appartement N° 5 de l’immeuble ayant le code ’120° 
avec un montant mensuel de 300 Dinars. Écrire une requête SQL permettant de prendre en compte ce 
client dans la base de données sachant qu’il possède les informations suivantes : 


NumCIN 
01234567 





AdrClient 
Tunis 


NomClient GenreClient 
Ali Wafi M 


TelClient 
79123345 


























INSERT INTO CLIENT VALUES ('01234567”, ?Ali Wafi’, M”, ‘Tunis’, 79123345”) ; 
INSERT INTO LOUER VALUES ('01234567”, °120”, 5, 23/04/2015”, 300) ; 


5) Écrire une requéte SQL permettant d'augmenter de 5% tous les loyers mensuels dont la location est 
faite avant le “01/01/2010”. 
UPDATE LOUER SET LoyerMensuel = LoyerMensuel*1.05 


WHERE DateLoc < ”01/01/2010”; 


6) En supprimant un client, quelles sont les tables qui seront touchées ? Justifier votre réponse. 


= Les tables qui seront touchées sont : la table « CLIENT» et la table « LOUER » 

= Justification : La table « CLIENT » est touchée directement par la requête et la table 
« LOUER » par la présence de la clause « ON DELETE CASCADE » avec la clé étrangère 
NumCIN. 
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7) Écrire les requêtes SQL permettant d’afficher : 


a) le nombre d’appartements de chaque immeuble sous le format indiqué ci-après. 





Code Immeuble Nombre d’appartements 

















SELECT Codelmmeuble AS ° Code Immeuble’, Count(NumAppart) AS "Nombre 
d”appartements” 


FROM APPARTEMENT 
GROUP BY Codelmmeuble; 


b) le total des loyers mensuels des appartements appartenant à l’agence identifiée par A 12”. 
SELECT SUM (LoyerMensuel) 
FROM IMMEUBLE I, LOUER L 
WHERE I.Codelmmeuble = L.Codelmmeuble 
AND IdAgence = ?A12”; 
Exercice 3 : (8 points = 3,25 + 1,25 + 1,00 + 2,50) 
1) Liste des colonnes : 


NB : Les colonnes qui seront prises en compte : « Nom de la colonne » et « Sujet » 































































































Des Description Type Taille Sujet 
MatPres Matricule du prestataire Texte 10 | Prestataire 
NomPres Nom du prestataire Texte 30 | Prestataire 
AdrPres Adresse du prestataire Texte 50 | Prestataire 
TelPres N° du téléphone du prestataire Texte 8 | Prestataire 
IPServ Adresse IP du serveur Texte 20 | Serveur 
DNSServ Nom du domaine du serveur Texte 30 | Serveur 
FreqServ Fréquence du processeur du serveur (GHz) | Numérique | (4,2) | Serveur 
CapServ Capacité de stockage du serveur (To) Numérique 4 | Serveur 
CodeOffre Code de l’offre d’un prestataire Texte 10 | Offre 
Slogan Slogan de l’offre Texte 20 | Offre 
Capacite Capacité offerte (GHz) Numérique 3 | Offre 
PrixAnnuel Prix forfaitaire annuel de l’offre Numérique | (4,2) | Offre 
TailleMax Taille maximale d’un fichier (MHz) Numérique 3 | Offre 
IdCI Identifiant du client Texte 5 | Client 
NomCl Nom du client Texte 20 | Client 
PreCl Prénom du client Texte 20 | Client 
AdrCl Adresse du client Texte 50 | Client 
TelCI N° du téléphone du client Texte 8 | Client 
RefCont Référence du contrat Texte 10 | Contrat 
DateDeb Date de début du contrat Date - | Contrat 
PerVal Période de validité du contrat Numérique 2 | Contrat 
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2) La liste des tables : (1,25 point = 5 x 0,25) 


























Nom table Description Sujet 
PRESTATAIRE | Regroupe les informations relatives aux prestataires Prestataire 
SERVEUR Regroupe les informations relatives aux serveurs Serveur 
OFFRE Regroupe les informations relatives aux offres des prestataires Offre 
CLIENT Regroupe les informations relatives aux clients Client 
CONTRAT Regroupe les informations relatives aux contrats des clients Contrat 








3) La liste des liens entre les tables : (1,00 point = 4 x 0,25) 





























Table mère Table fille Clé primaire Clé étrangère 
PRESTATAIRE SERVEUR MatPres MatPres 
PRESTATAIRE OFFRE MatPres MatPres 
CLIENT CONTRAT IdCI IdCI 
OFFRE CONTRAT CodeOffre CodeOffre 





4) Représentation textuelle : (2,50 points) 


PRESTATAIRE (MatPres, NomPres, AdrPres, TelPres) 


SERVEUR (IPServ, DNSServ, FreqServ, CapServ, MatPres#) 


OFFRE (CodeOffre, Slogan, Capacite, PrixAnnuel, TailleMax, MatPres#) 


CLIENT (ICI, NomCl, PreCl, AdrCl, TelCl) 


CONTRAT (RefCont, DateDeb, PerVal, IdCI#, CodeOffre#) 
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Le sujet comporte 8 pages, les réponses doivent être rédigées sur ces mêmes pages qui 
doivent être remises à la fin de l’épreuve. 


Exercice 1 : (5 points) 


Le propriétaire d’une grande pharmacie souhaite installer une application développée autour d’une base 
de données. Cette application permet de gérer les ventes et les stocks des médicaments, des produits 
cosmétiques et parapharmaceutiques. Afin d’assurer une bonne exploitation et sécurisation des données 


entre les différents agents de la pharmacie, le propriétaire vous demande de l’aider à la mettre en place 


1) Après avoir consulté les applications disponibles sur le marché, le propriétaire a remarqué que quelques- 
unes utilisent le mode « Monoposte » et d’autres utilisent le mode « Client/Serveur ». 


a) Quel mode choisissez-vous ? occccocnoonioicnonconononco ccoo connn conc cocoa nnconcnccicancn 


b) Définissez ce mode : 


2) Une fois l’application est installée avec succès et lors de la démonstration de ses différentes 


fonctionnalités, on a constaté les deux interfaces suivantes. Donner le nom et la définition de chaque 
interface. 





RS [Medicament] 





Gestion des Médicaments 





Code fournisseur : Nom fournisseur : 

ki 

o 

© 

& Liste médicaments Ce Cp CP A MES HE 

D 

+ 

E 
O EN 
Définition 
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Ei Pharmacie- [Stock] 


FICHE DE STOCK MEDICAMENT 
Année : 2015 


Code Medicament: 300420: 


Designation “somos Stock maximum: 200% 





Valeur Sortie [Stock restant | Valeur stock 





Interface 2 

















3) Après avoir implémenté la base de données, le propriétaire de la pharmacie souhaite étudier les risques 


possibles pour garantir sa sécurité. 


Compléter le tableau suivant par le mécanisme de sécurité approprié pour chaque risque prévu. 





Risque prévu Mécanisme de sécurité 





Tout le contenu de la base de données est accessible à 


a 2... eee NE 





Les utilisateurs se connectent á la base de données sans 


o E MPa 





Un utilisateur provoque une perte de données suite á une 


vis manipulation. In a ao conta aaa 











Exercice 2 : (7 points) 


Une société de développement souhaite implémenter un site Internet de mises en enchères en ligne destiné 


à un groupe de revendeurs. Pour cela, elle a conçu une base de données simplifiée décrite par la 
représentation textuelle suivante : 


PL ==> 
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MEMBRE (IdMembre, Nom, Prenom, Adresse, Tel) 


ARTICLE (IdArticle, Libelle, DateDeb, DateFin, PrixDep, PrixMin, Statut, IdVendeur#) 


ENCHERE (IArticle#, IdEncherisseur#, DateEnchere, Montant) 





N.B. : Toute personne, désirant participer aux opérations de mises en enchères (vendeur ou enchérisseur), 


doit s’inscrire comme membre dans ce site. 


Description des colonnes des tables 



































Nom de 1 Nom de 1 
AENA Description de la colonne ra EIA Description de la colonne 
colonne colonne 
Dateeth la fi t Particl 
IdMembre Identifiant d’un membre du site DateFin Ara dl Alo 
dans le site 
Nom Nom d'un membre du site PrixDep Prix de départ proposé 
Prenom Prénom d'un membre du site PrixMin Prix minimum de vente autorisé 
Adresse Adresse d'un membre du site Statut o C VIe Nedas Ng Non 
Vendu) 
Tel N° de téléphone d’un membre du site IdVendeur Identifiant du vendeur (Membre) 
IdArticle Identifiant de l’article à vendre IdEncherisseur | Identifiant de l’enchérisseur (Membre) 
Libelle Libellé de l’article à vendre DateEnchere Date de l’enchère 
Date et h de début d te d 
DateDeb > e ie ; ASE Montant Montant de l’enchère 
l’article dans le site 














1) Ecrire la requête SQL permettant de créer la table ENCHERE à partir de la description suivante : 





























Colonne Type Taille Contraintes 
IdArticle Texte 8 Clé primaire, Clé étrangère 
IdEncherisseur Texte 8 Clé primaire, Clé étrangère 
DateEnchere Date&Heure Clé primaire 
Montant Décimal (15,3) Non nul 











2) Un nouveau membre vient de s’inscrire dans le site ayant les informations suivantes : 





IdMembre Nom Prenom Adresse Tel 


VNO0260077 Mabrouk Yemen Rue Ibn Sina 79333555 


























a) Ecrire la requête SQL permettant d’ajouter ces données à la table appropriée. 


b) Après l’exécution de cette requête, un message d’erreur s’affiche. Identifier l’origine de cette 
erreur. 


3) Ecrire les requêtes SQL permettant d’afficher : 
a) l'identifiant, le nom et le prénom du vendeur qui a proposé l’article identifié par AR002605. 


c) la liste des articles (identifiant et libellé) triée par ordre décroissant selon le libellé et dont le 


montant proposé à l’enchère a dépassé le prix minimum de vente. 


d) le nom et le prénom de l’enchérisseur qui a proposé le plus grand montant pour l’article dont le 


libellé contient l’expression « Meuble ». 


Exercice 3 : (8 points) 


Une agence privée souhaite faire un recensement pour analyser les tendances des jeunes entre 18 et 25 ans 
dans les domaines du sport et de l’Internet. Afin de collecter les informations nécessaires, elle a procédé, à 
travers ses agents, au choix d’un échantillon (ensemble de jeunes) pris aléatoirement où chaque jeune 


remplit un questionnaire dont un exemple est présenté ci-après. 


Informations Personnelles 


N° CIN : 08194523 


Nom : Ben Saleh Prénom : Mohamed Sexe : Masculin 


Date de naissance : 24/09/1995 Adresse : Avenue Habib Bourguiba - Monastir Niveau d’enseignement 














Universitaire Secondaire Primaire Analphabète 



































Sports Pratiqués 





















































S| ports collectifs : Sports individuels : 
x | Football Tennis 
Handball x | Natation 
Volleyball x | Judo 
Basketball Cyclisme 
x | Rugby Athlétisme 
Internet 





ervices exploités : 





Services Nombre d’heures hebdomadaire de connexion 





x | Réseaux sociaux 14 





Messagerie électronique 





x | Téléchargement de fichiers 5 





Jeux & vidéo 
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S| x | E-commerce 3 























E-Learning 
Navigateurs Utilisés : 
x | Internet Explorer x | Mozilla Firefox 
Google Chrome Autres 














N.B. : Les sports, les services et les navigateurs Internet sont identifiés par des codes. 
Questions : 


On se propose d’implémenter une base de données permettant de gérer les données des questionnaires 


collectés. Pour cela, on vous demande : 


1) d'élaborer la liste des colonnes (nom de la colonne, description, type de données, taille, sujet). 2) 
de déduire la liste des tables. 
3) de donner la liste des liens entre les tables. 


4) d’en déduire une représentation textuelle de la base de données. 
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Exercice 1 : (5 points = 1,00 + 2,50 + 1,50) 

Le propriétaire d’une grande pharmacie souhaite installer une application développée autour 
d’une base de données. Cette application permet de gérer les ventes et les stocks des médicaments, 
des produits cosmétiques et parapharmaceutiques. Afin d’assurer une bonne exploitation et 
sécurisation des données entre les différents agents de la pharmacie, le propriétaire vous demande de 


l’aider à la mettre en place. 


1. Après avoir consulté les applications disponibles sur le marché, le propriétaire a remarqué que 
quelques-unes utilisent le mode « Monoposte » et d’autres utilisent le mode « Client/Serveur ». 


a) Quel mode choisissez-vous ? Le mode Client/Serveur. 


b) Définissez ce mode : Toutes les applications sont installées sur le serveur. 


Remarque : On acceptera aussi "La base de données se situe sur une machine dite « Serveur 
de données »." 


2. Une fois l’application est installée avec succès et lors de la démonstration de ses différentes 
fonctionnalités, on a constaté les deux interfaces suivantes. Donner le nom et la définition de 
chaque interface. 

Interfacel : 

© Nom : Formulaire 

O Définition : C’est une interface utilisateur qui permet aux utilisateurs d'interagir avec 
la base de données à travers des objets tels que les étiquettes, des cases à cocher, des 
boutons de commande, ... 

Interface 2 : 

© Nom : Etat 

$ Définition : C’est une mise en forme de données extraites à partir d’une Base de 
données, en vue d’être affichées ou imprimées. 
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Après avoir implémenté la base de données, le propriétaire de la pharmacie souhaite étudier les 
risques possibles pour garantir sa sécurité. 


Compléter le tableau suivant par le mécanisme de sécurité approprié pour chaque risque prévu. 























Risque prévu Mécanisme de sécurité 

Tout le contenu de la base de données est accessible à tous les : dns 

Confidentialité 
utilisateurs. 
Les utilisateurs se connectent à la base de données sans Poe 
A aie Authentification 
identifiants. 
Un utilisateur provoque une perte de données suite à une 

$ ; . Sauvegarde 

mauvaise manipulation. 





Exercice 2 : (7 points = 1,50 + 1,50 + 1,00 + 1,00 + 1,00 + 1,00) 


Une société de développement souhaite implémenter un site Internet de mises en enchères en ligne 


destiné à un groupe de revendeurs. Pour cela, elle a conçu une base de données simplifiée décrite par la 


représentation textuelle suivante : 


MEMBRE (IdMembre, Nom, Prenom, Adresse, Tel) 


ARTICLE (IdArticle, Libelle, DateDeb, DateFin, PrixDep, PrixMin, Statut, IdVendeur#) 


ENCHERE (IdArticle#, IdEncherisseur#, DateEnchere, Montant) 


N.B. : Toute personne, désirant participer aux opérations de mises en enchères (vendeur ou 


enchérisseur), doit s’inscrire comme membre dans ce site. 


1) 


2) 


Ecrire la requête SQL permettant de créer la table ENCHERE à partir de la description suivante : 


CREATE TABLE ENCHERE ( 
IdArticle varchar(8), 
IdEncherisseur varchar(8), 


DateEnchere datetime, 

Montant decimal(15,3) NOT NULL, 

CONSTRAINT PK PRIMARY KEY (IdArticle, IdEncherisseur, DateEnchere), 
CONSTRAINT FK1 FOREIGN KEY (IdArticle) REFERENCES ARTICLE (IdArticle), 


CONSTRAINT FK2 FOREIGN KEY (IdEncherisseur) REFERENCES MEMBRE 
(IdMembre)); 


Ecrire la requête SQL permettant d’ajouter ces données à la table appropriée. 


INSERT INTO MEMBRE 
VALUES ("VN00260077”, ° Mabrouk’, "Yemen”, "Rue Ibn Sina’, 79333555”) ; 
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3) 


Après l’exécution de cette requête, un message d’erreur s’affiche. Identifier l’origine de cette 
erreur. 


L’IdMembre est formé de 10 caractères, qui correspond à l’/dEncherisseur défini avec une 
taille de 8 caractères donc il est impossible d’ajouter ces données. 


Ecrire les requêtes SQL permettant d’afficher : 


l'identifiant, le nom et le prénom du vendeur qui a proposé l’article identifié par AR002605. 


SELECT IdMembre, Nom, Prenom 
FROM MEMBRE M, ARTICLE A 
WHERE A.ld Vendeur = M.IdMembre 
AND IdArticle=?AR002605 ; 


le nombre d’articles vendus par le membre ayant l’identifiant VN006453. 


SELECT COUNT(*) As NbArticle 

FROM ARTICLE 

WHERE IdVendeur = ?VN006453” 

AND Statut = ‘V’ ; 

la liste des articles (identifiant et libellé) triée par ordre décroissant selon le libellé et dont le montant 


proposé à l’enchère a dépassé le prix minimum de vente. 


SELECT A.IdArticle, Libelle 

FROM ARTICLE A, ENCHERE E 

WHERE A.IdArticle = E.IdArticle 

AND E.Montant > A.PrixMin 

ORDER BY Libelle DESC ; 

le nom et le prénom de l’enchérisseur qui a proposé le plus grand montant pour l’article dont le 


libellé contient l’expression « Meuble ». 
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Exercice 3 : (8 points = 3,00 + 1,75 + 1,50 + 1,75) 


1) Liste des colonnes : (3 points) 














































































































re Description Le Taille Sujet 
NumCIN Numéro de carte d’identité du jeune Texte 8 | Jeune 
Nom Nom du jeune Texte 15 | Jeune 
Prenom Prénom du jeune Texte 15 | Jeune 
Sexe Sexe du jeune Texte 1 | Jeune 
DateNais Date de naissance du jeune Date - | Jeune 
Adresse Adresse du jeune Texte 50 | Jeune 
Niveau Niveau d’enseignement du jeune Texte 1 | Jeune 
CodeSport Code du sport Texte 3 | Sport 
LibSport Libellé du sport Texte 20 | Sport 
TypeSport Type du sport (T: Individuel ;”C” : Texte 1 | Sport 

Collectif) 
CodeServ Code du service Internet Texte 3 | Service 
LibServ Libellé du service Internet Texte 20 | Service 
CodeSport Code du sport Texte 3 | Pratiquer 
CodeServ Code du service Internet Texte 3 | Exploiter 
NbHeure Nombre d’heures hebdomadaire de Numérique 3 | Exploiter 
connexion 
CodeNav Code du navigateur Texte 3 | Navigate 
ur 
LibNav Libellé du navigateur Texte 20 | Navigate 
ur 
CodeNav Code du navigateur Texte 3 | Naviguer 
2) La liste des tables : (1,75 points = 7 x 0,25) 

Nom table Description Sujet 
JEUNE Regroupe l’ensemble des informations relatives aux jeunes Jeune 
SPORT Regroupe l’ensemble des informations relatives aux sports Sport 
SERVICE Regroupe l’ensemble des informations relatives aux services Service 
NAVIGATEUR | Regroupe l’ensemble des informations relatives aux navigateurs Navigateur 
PRATIQUER Regroupe l’ensemble des informations relatives à la table PRATIQUER | Pratiquer 
EXPLOITER Regroupe l’ensemble des informations relatives à la table EXPLOITER | Exploiter 
NAVIGUER Regroupe l’ensemble des informations relatives à la table NAVIGUER Naviguer 
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3) La liste des liens entre les tables : (1,50 points = 6 x 0,25) 























Table mère Table fille Clé primaire Clé étrangère 
JEUNE PRATIQUER NumCIN NumCIN 
SPORT PRATIQUER CodeSport CodeSport 
JEUNE EXPLOITER NumCIN NumCIN 
SERVICE EXPLOITER CodeServ CodeServ 
JEUNE NAVIGUER NumCIN NumCIN 
NAVIGATEUR | NAVIGUER CodeNav CodeNav 




















4) Représentation textuelle : (1,75 points = 7 x 0,25) 


JEUNE (NumCIN, Nom,Prenom, Sexe,DateNais, Adresse, Niveau) 
SPORT (CodeSport, LibSport, TypeSport) 

SERVICE (CodeServ, LibServ) 

NAVIGATEUR (CodeNav, LibNav) 

PRATIQUER (NumCIN#, CodeSport#) 

EXPLOITER (NumCIN#, CodeServ#, NbHeure) 

NAVIGUER (NumCIN#, CodeNav#) 
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